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.
- package/.vscode/settings.json +6 -0
- package/README.md +10 -10
- package/controls/Active_HTML_Document.js +116 -116
- package/controls/README.md +7 -7
- package/controls/page/admin.js +74 -74
- package/controls/panel/admin.js +11 -11
- package/examples/_css/basic.css +913 -913
- package/examples/_css/database-control.css +51 -51
- package/examples/_css/jsgui.css +66 -66
- package/examples/_css/multi-layout.css +23 -23
- package/examples/_css/style.css +1669 -1669
- package/examples/_css/top-and-bottom-bars.css +54 -54
- package/examples/box/1) square box/client.js +188 -188
- package/examples/box/1) square box/server.js +112 -112
- package/examples/box/2) twenty square boxes/css flex wrap/client.js +112 -248
- package/examples/box/2) twenty square boxes/css flex wrap/server.js +39 -112
- package/examples/box/3) twenty selectable square boxes/css flex wrap/client.js +129 -0
- package/examples/{controls/15) window, text field → box/3) twenty selectable square boxes/css flex wrap}/server.js +38 -38
- package/examples/boxes/square_boxes.js +45 -48
- package/examples/boxes/square_boxes_client.js +132 -136
- package/examples/client-side-popup-menu-button.html +93 -93
- package/examples/color_palette.js +51 -51
- package/examples/color_palette_client.js +95 -95
- package/examples/controls/1) window/client.js +186 -186
- package/examples/controls/1) window/server.js +117 -117
- package/examples/controls/10) window, mirrored text inputs/client.js +118 -320
- package/examples/controls/10) window, mirrored text inputs/server.js +37 -117
- package/examples/controls/11) window, mirrored text fields/client.js +493 -251
- package/examples/controls/11) window, mirrored text fields/server.js +117 -117
- package/examples/controls/11b) window, shared Data_Object model mirrored text fields/client.js +613 -331
- package/examples/controls/11b) window, shared Data_Object model mirrored text fields/server.js +117 -117
- package/examples/controls/11c) window, shared Data_Value model mirrored text fields/client.js +617 -617
- package/examples/controls/11c) window, shared Data_Value model mirrored text fields/server.js +117 -117
- package/examples/controls/11d) window, shared model mirrored integer text fields/client.js +611 -280
- package/examples/controls/11d) window, shared model mirrored integer text fields/server.js +134 -22
- package/examples/controls/12) window, Select_Options control/client.js +66 -452
- package/examples/controls/12) window, Select_Options control/server.js +19 -117
- package/examples/controls/13) window, Dropdown_Menu control/client.js +66 -0
- package/examples/controls/13) window, Dropdown_Menu control/server.js +20 -0
- package/examples/controls/2) two windows/client.js +193 -193
- package/examples/controls/2) two windows/server.js +113 -113
- package/examples/controls/3) five windows/client.js +217 -217
- package/examples/controls/3) five windows/server.js +116 -115
- package/examples/controls/4) window, tabbed panel/client.js +54 -225
- package/examples/controls/4) window, tabbed panel/server.js +17 -117
- package/examples/controls/5) window, grid/client.js +204 -484
- package/examples/controls/5) window, grid/server.js +117 -119
- package/examples/controls/6) window, color_palette/client.js +68 -204
- package/examples/controls/6) window, color_palette/server.js +117 -117
- package/examples/controls/7) window, month_view/client.js +40 -231
- package/examples/controls/7) window, month_view/server.js +117 -117
- package/examples/controls/8) window, checkbox/client.js +33 -209
- package/examples/controls/8) window, checkbox/server.js +117 -117
- package/examples/controls/9) window, date picker/client.js +76 -303
- package/examples/controls/9) window, date picker/server.js +117 -117
- package/examples/controls/9b) window, shared data.model mirrored date pickers/README.md +51 -0
- package/examples/controls/9b) window, shared data.model mirrored date pickers/client.js +83 -398
- package/examples/controls/9b) window, shared data.model mirrored date pickers/server.js +117 -117
- package/examples/controls/__old/_html-server-color-palette.js +114 -114
- package/examples/controls/__old/html-server-combo-box.js +104 -104
- package/examples/controls/__old/html-server-list.js +98 -98
- package/examples/controls/__old/html-server-popup-menu-button.js +114 -114
- package/examples/controls/__old/html-server-start-stop-toggle-button.js +146 -146
- package/examples/controls/__old/scs-arrow-button.js +36 -36
- package/examples/controls/__old/scs-date-picker.js +157 -157
- package/examples/controls/__old/scs-file-browser.js +82 -82
- package/examples/controls/__old/scs-item.js +159 -159
- package/examples/controls/__old/scs-month-arrow-selector.js +126 -126
- package/examples/controls/__old/scs-month-view.js +94 -94
- package/examples/controls/__old/scs-start-stop-toggle-button.js +40 -40
- package/examples/controls/__old/scs-tree.js +49 -49
- package/examples/controls/__old/scs-year-arrow-selector.js +127 -127
- package/examples/demos/date-picker.js +119 -119
- package/examples/demos/explain-encapsulation.js +9 -9
- package/examples/demos/resizing.js +35 -35
- package/examples/demos/server_time.js +6 -6
- package/examples/grids/grid_1.js +45 -45
- package/examples/grids/grid_1_client.js +329 -329
- package/examples/html-rendering.js +20 -20
- package/examples/html-server.js +105 -105
- package/examples/introducing jsgui3/server.js +110 -110
- package/examples/mx_display/mx_display_1.js +45 -45
- package/examples/mx_display/mx_display_1_client.js +444 -444
- package/fs2.js +1836 -1836
- package/http/responders/HTTP_Responder.js +15 -15
- package/http/responders/static/Static_Route_HTTP_Responder.js +105 -105
- package/module.js +34 -34
- package/old/_single-control-server.js +418 -418
- package/old/single-control-server.js +368 -368
- package/old/single-page-app.js +131 -131
- package/package.json +42 -42
- package/page-context.js +92 -92
- package/publishers/helpers/assigners/Assigner.js +10 -10
- package/publishers/helpers/assigners/static-compressed-response-buffers/Single_Control_Webpage_Server_Static_Compressed_Response_Buffers_Assigner.js +150 -150
- package/publishers/helpers/assigners/static-headers/Single_Control_Webpage_Server_Static_Headers_Assigner.js +109 -109
- package/publishers/helpers/assigners/static-routes/Single_Control_Webpage_Server_Static_Routes_Assigner.js +91 -91
- package/publishers/helpers/assigners/static-uncompressed-response-buffers/Single_Control_Webpage_Server_Static_Uncompressed_Response_Buffers_Assigner.js +104 -104
- package/publishers/helpers/preparers/static/bundle/Ready_To_Serve_Preparer.js +18 -18
- package/publishers/helpers/preparers/static/bundle/Static_Routes_Responses_Webpage_Bundle_Preparer.js +44 -44
- package/publishers/http-function-publisher.js +212 -212
- package/publishers/http-html-page-publisher.js +5 -5
- package/publishers/http-html-publisher.js +24 -24
- package/publishers/http-js-publisher.js +135 -135
- package/publishers/http-observable-publisher.js +124 -124
- package/publishers/http-publisher.js +53 -53
- package/publishers/http-resource-publisher.js +325 -325
- package/publishers/http-webpage-publisher.js +659 -658
- package/publishers/http-webpageorsite-publisher.js +343 -343
- package/publishers/http-website-publisher.js +640 -640
- package/publishers/notes.md +9 -9
- package/resources/README.md +16 -16
- package/resources/_old_website-javascript-resource.js +994 -994
- package/resources/_old_website-resource.js +507 -507
- package/resources/compile/server-resource-compilation.js +43 -43
- package/resources/data-resource.js +118 -118
- package/resources/fs-resource.js +146 -146
- package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -105
- package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +42 -42
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +41 -41
- package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Node.js +93 -93
- package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +253 -253
- package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +337 -337
- package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +96 -96
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +37 -37
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +61 -61
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +72 -72
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +92 -92
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -29
- package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -116
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +159 -159
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +178 -178
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +87 -87
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +91 -91
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +136 -136
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +73 -73
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +85 -85
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +42 -42
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +40 -40
- package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +54 -54
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +45 -45
- package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +343 -343
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +38 -38
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +30 -30
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +28 -28
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +26 -26
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +8 -8
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +21 -21
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +89 -89
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +8 -8
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +27 -27
- package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +28 -28
- package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +736 -736
- package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +64 -64
- package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +31 -31
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -15
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +305 -305
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +77 -77
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +248 -248
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +138 -138
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -10
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +100 -100
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +60 -60
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +179 -179
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -43
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -12
- package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -35
- package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -11
- package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +31 -31
- package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +37 -37
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +39 -39
- package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -25
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +200 -200
- package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +43 -43
- package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +76 -76
- package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +227 -227
- package/resources/jsbuilder/JS_AST/query/find_object_keys.js +404 -404
- package/resources/jsbuilder/JS_AST/query/node_queries.js +8 -8
- package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +11 -11
- package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +85 -85
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +123 -123
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +87 -87
- package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +10 -10
- package/resources/jsbuilder/JS_Builder.js +10 -10
- package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +31 -31
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +25 -25
- package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +78 -78
- package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +17 -17
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +25 -25
- package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +8 -8
- package/resources/jsbuilder/JS_File/JS_File.js +12 -12
- package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -202
- package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -175
- package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -81
- package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -86
- package/resources/jsbuilder/JS_File/JS_File_4-Query.js +413 -413
- package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +414 -414
- package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -59
- package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -24
- package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -12
- package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +23 -23
- package/resources/jsbuilder/JS_File/JS_File_Import_References.js +31 -31
- package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -16
- package/resources/jsbuilder/JS_File/JS_Files.js +15 -15
- package/resources/jsbuilder/Module.js +14 -14
- package/resources/jsbuilder/Platform.js +13 -13
- package/resources/jsbuilder/Platforms.js +69 -69
- package/resources/jsbuilder/Project.js +109 -109
- package/resources/jsbuilder/Reference.js +1 -1
- package/resources/jsbuilder/Reference_Sequence.js +16 -16
- package/resources/jsbuilder/Scope.js +29 -29
- package/resources/jsbuilder/Variable_Name_Provider.js +42 -42
- package/resources/jsbuilder/_JS_File.js +225 -225
- package/resources/jsbuilder/ast_query.js +20 -20
- package/resources/jsbuilder/babel/babel_consts.js +162 -162
- package/resources/jsbuilder/babel/babel_node_tools.js +541 -541
- package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +923 -904
- package/resources/jsbuilder/build.js +16 -16
- package/resources/jsbuilder/platform_notes.md +66 -66
- package/resources/jsbuilder/test/test_ast_node.js +381 -381
- package/resources/jsbuilder/test/test_js_file.js +303 -303
- package/resources/jsbuilder/test/test_project.js +157 -157
- package/resources/local-server-info-resource.js +96 -96
- package/resources/notes.txt +10 -10
- package/resources/old/website-image-resource.js +1185 -1185
- package/resources/process-js.js +498 -498
- package/resources/processors/bundlers/bundle.js +29 -29
- package/resources/processors/bundlers/bundler.js +23 -23
- package/resources/processors/bundlers/css-bundler.js +234 -234
- package/resources/processors/bundlers/js/JS_Bundler.js +51 -51
- package/resources/processors/bundlers/js/esbuild/Advanced_JS_Bundler_Using_ESBuild.js +388 -391
- package/resources/processors/bundlers/js/esbuild/Bundler_Using_ESBuild.js +8 -8
- package/resources/processors/bundlers/js/esbuild/Core_JS_Non_Minifying_Bundler_Using_ESBuild.js +188 -188
- package/resources/processors/bundlers/js/esbuild/Core_JS_Single_File_Minifying_Bundler_Using_ESBuild.js +191 -192
- package/resources/processors/bundlers/js/esbuild/_Old_CSS_Extractor.js +239 -239
- package/resources/processors/bundlers/js-bundler.js +263 -263
- package/resources/processors/bundlers/test_ast.js +73 -73
- package/resources/processors/bundlers/webpage-bundler.js +404 -404
- package/resources/processors/bundlers/website-bundler.js +22 -22
- package/resources/processors/extractors/Extractor.js +9 -11
- package/resources/processors/extractors/js/css_and_js/AST_Node/CSS_And_JS_From_JS_String_Using_AST_Node_Extractor.js +239 -254
- package/resources/processors/extractors/js/css_and_js/CSS_And_JS_From_JS_String_Extractor.js +3 -3
- package/resources/processors/extractors/string/Pos_Span_String_Extractor.js +93 -93
- package/resources/server-installed-tools.js +28 -28
- package/resources/server-resource-pool.js +41 -41
- package/resources/website-audio-resource.js +735 -735
- package/resources/website-css-resource.js +411 -411
- package/resources/website-image-resource.js +412 -412
- package/resources/website-javascript-resource-processor.js +908 -908
- package/resources/website-javascript-resource.js +874 -874
- package/resources/website-resource-processor.js +10 -10
- package/resources/website-resource.js +164 -164
- package/resources/website-static-html-resource.js +199 -199
- package/resources/website-template-html-resource.js +231 -231
- package/roadmap.md +75 -75
- package/server.js +609 -573
- package/static-page-context.js +13 -13
- package/website/webpage.js +81 -81
- package/website/website-group.js +15 -15
- package/website/website.js +260 -260
- package/examples/controls/11d) window, shared model mirrored integer text fields/both.js +0 -17
- package/examples/controls/13) window, shared model mirrored lat_long/client.js +0 -933
- package/examples/controls/13) window, shared model mirrored lat_long/server.js +0 -50
- package/examples/controls/14) window, control compositional model/client.js +0 -328
- package/examples/controls/14) window, control compositional model/server.js +0 -118
- package/examples/controls/14a) window, control spec has compositional model/client.js +0 -440
- package/examples/controls/14a) window, control spec has compositional model/server.js +0 -118
- package/examples/controls/15) window, text field/client.js +0 -256
- package/examples/controls/16) Window([Text_Input])/client.js +0 -266
- package/examples/controls/16) Window([Text_Input])/server.js +0 -109
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/client.js +0 -494
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/isomorphic.js +0 -24
- package/examples/controls/16a) Window([Text_Input]) Integer data.model.data_type/server.js +0 -73
- package/examples/controls/2b) two window, context menus/client.js +0 -193
- package/examples/controls/2b) two window, context menus/server.js +0 -114
- package/examples/controls/4a) window, tabbed panel with various controls inside/client.js +0 -233
- package/examples/controls/4a) window, tabbed panel with various controls inside/server.js +0 -118
|
@@ -1,405 +1,405 @@
|
|
|
1
|
-
// Basically need to split things up into isolated and specific encapsulated pieces of functionality.
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
// Just need to make the appropriate class names and structures....
|
|
5
|
-
|
|
6
|
-
// And CSS from JS extraction.
|
|
7
|
-
// Maybe even JS from JS.
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
// Late 2023 - Looks best to retire this one, make it really flexible in terms of what it does internally, with (many?) more classes doing
|
|
11
|
-
// specific things. It looks like ESBuild is the fastest option, may need to mix that with some very specific pieces of functionality
|
|
12
|
-
// for things like splitting / extracting CSS.
|
|
13
|
-
|
|
14
|
-
// Will identify the various parts of the tasks involved in bundling (and then serving) assets on the web.
|
|
15
|
-
// Will make classes that are named 1st in terms of that they do, but then there will be directories with different implementations
|
|
16
|
-
// of that functionality.
|
|
17
|
-
|
|
18
|
-
// May well be worth having this link to (require and export) an improved and specific version of the Webpage_Bundler class.
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const Bundler = require('./bundler');
|
|
26
|
-
|
|
27
|
-
const JS_Bundler = require('./js-bundler');
|
|
28
|
-
const CSS_Bundler = require('./css-bundler');
|
|
29
|
-
|
|
30
|
-
const {bundle_css_from_js_str, stream_html_basic_css} = CSS_Bundler;
|
|
31
|
-
|
|
32
|
-
const Bundle = require('./bundle');
|
|
33
|
-
const {obs, prom_or_cb} = require('fnl');
|
|
34
|
-
const fnlfs = require('fnlfs');
|
|
35
|
-
const {tof, HTML_Document, Client_HTML_Document, Control} = require('jsgui3-html');
|
|
36
|
-
const util = require('util');
|
|
37
|
-
const Server_Page_Context = require('../../../page-context');
|
|
38
|
-
// Will put the JS together. Maybe images?
|
|
39
|
-
// Get everything ready to serve.
|
|
40
|
-
//const browserify = require('browserify');
|
|
41
|
-
const babel = require('@babel/core');
|
|
42
|
-
const stream_to_array = require('stream-to-array');
|
|
43
|
-
|
|
44
|
-
const {bundle_js} = JS_Bundler;
|
|
45
|
-
// Observable to load the basic CSS, or return it.
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
// This may / will be another part of it.
|
|
49
|
-
// Or a specific analysis / css extraction part of the build.
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
const get_basic_css_content_obj = () => {
|
|
56
|
-
return obs((next, complete, error) => {
|
|
57
|
-
|
|
58
|
-
const s_css = stream_html_basic_css();
|
|
59
|
-
|
|
60
|
-
const chunks = [];
|
|
61
|
-
let buf_css;
|
|
62
|
-
|
|
63
|
-
s_css.once('end', () => {
|
|
64
|
-
// create the final data Buffer from data chunks;
|
|
65
|
-
buf_css = Buffer.concat(chunks);
|
|
66
|
-
complete({
|
|
67
|
-
'value': buf_css,
|
|
68
|
-
'content-type': 'text/css'
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
// Of course, you can do anything else you need to here, like emit an event!
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
// Data is flushed from fileStream in chunks,
|
|
75
|
-
// this callback will be executed for each chunk
|
|
76
|
-
s_css.on('data', (chunk) => {
|
|
77
|
-
chunks.push(chunk); // push data chunk to array
|
|
78
|
-
|
|
79
|
-
// We can perform actions on the partial data we have so far!
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
// /bundlers/webpage/babel-and-browserify
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
// Webpage_Bundler_Using_Babel_And_Browserify
|
|
90
|
-
// Webpage_Bundler_Using_ESBuild
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
// Multiple steps...
|
|
94
|
-
// Initial step of building to 1 js file, and also extracting other content from the JS, such as CSS.
|
|
95
|
-
// Possibly want to remove that CSS from the JS?
|
|
96
|
-
// Possibly want it in the CSS file rather than the JS.
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
// Interpret / compile (from) JS?
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
// Split JS to JS and CSS?
|
|
104
|
-
// And do that with the built (initially built) JS....
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
// Extract bundle pieces from... js file(s).
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
// Resource_Transformer???
|
|
113
|
-
|
|
114
|
-
// JS_To_JS????
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
const bundle_web_page = (webpage, options = {}) => {
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
// But we need specific bundlers that use specific tools internally.
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
// Nice here as an obs fn.
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
const {content} = webpage;
|
|
138
|
-
let {disk_path_client_js} = options;
|
|
139
|
-
|
|
140
|
-
const t_content = tof(content);
|
|
141
|
-
console.log('t_content', t_content);
|
|
142
|
-
|
|
143
|
-
return obs((next, complete, error) => {
|
|
144
|
-
const res = new Bundle();
|
|
145
|
-
(async () => {
|
|
146
|
-
const o_basic_css = await get_basic_css_content_obj();
|
|
147
|
-
if (t_content === 'string') {
|
|
148
|
-
const buff = Buffer.from(`<html><head><title>${webpage.title}</title></head><body>${content}</body></html>`, "utf-8");
|
|
149
|
-
res.push({
|
|
150
|
-
'path': webpage.path,
|
|
151
|
-
'value': buff,
|
|
152
|
-
'content-type': 'text/html'
|
|
153
|
-
});
|
|
154
|
-
complete(res);
|
|
155
|
-
} else if (t_content === 'control') {
|
|
156
|
-
if (content instanceof Control) {
|
|
157
|
-
//console.log('content is control');
|
|
158
|
-
//console.log('content.constructor.name', content.constructor.name);
|
|
159
|
-
if (content instanceof HTML_Document) {
|
|
160
|
-
console.log('content is an html document');
|
|
161
|
-
// May in fact be much easier.
|
|
162
|
-
// Assume already bundled?
|
|
163
|
-
// Probably best not to.
|
|
164
|
-
|
|
165
|
-
// Want to have nicely named functions that get called to do things.
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
throw 'NYI';
|
|
170
|
-
} else {
|
|
171
|
-
const diskpath_js_client = disk_path_client_js || require.resolve('jsgui3-html');
|
|
172
|
-
res_bundle_js = await bundle_js(diskpath_js_client, {
|
|
173
|
-
'js_mode': 'mini',
|
|
174
|
-
'babel': 'mini'
|
|
175
|
-
});
|
|
176
|
-
console.log('res_bundle_js', res_bundle_js);
|
|
177
|
-
throw 'NYI';
|
|
178
|
-
|
|
179
|
-
/*
|
|
180
|
-
|
|
181
|
-
bundle_js(diskpath_js_client, {
|
|
182
|
-
'js_mode': 'mini',
|
|
183
|
-
'babel': 'mini'
|
|
184
|
-
}, (err, res_bundle_js) => {
|
|
185
|
-
if (err) {
|
|
186
|
-
console.trace();
|
|
187
|
-
throw err;
|
|
188
|
-
} else {
|
|
189
|
-
//console.log('res_bundle_js', res_bundle_js);
|
|
190
|
-
|
|
191
|
-
// Could search at this point for class.css properties.
|
|
192
|
-
res.push({
|
|
193
|
-
'path': webpage.path + 'js/app.js',
|
|
194
|
-
'value': res_bundle_js,
|
|
195
|
-
'content-type': 'text/javascript'
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
const spc = new Server_Page_Context({
|
|
199
|
-
//request:
|
|
200
|
-
});
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
const doc = new Client_HTML_Document({
|
|
204
|
-
context: spc
|
|
205
|
-
});
|
|
206
|
-
doc.include_js('/js/app.js');
|
|
207
|
-
doc.body.add(content);
|
|
208
|
-
|
|
209
|
-
// Getting it to load the JS would be nice...
|
|
210
|
-
// But maybe only do it automatically if it's an active document.
|
|
211
|
-
// If it's just generated JS then best not to bundle JS to load.
|
|
212
|
-
|
|
213
|
-
// Could also make smaller bundles for some specific parts of the app. Could improve speed.
|
|
214
|
-
//console.log('doc.html', doc.html);
|
|
215
|
-
const buff_html = Buffer.from(doc.html, "utf-8");
|
|
216
|
-
// But add the client-side stuff to that doc.
|
|
217
|
-
|
|
218
|
-
// Remember, this part is about bundling rather than serving.
|
|
219
|
-
|
|
220
|
-
res.push({
|
|
221
|
-
'path': webpage.path,
|
|
222
|
-
'value': buff_html,
|
|
223
|
-
'content-type': 'text/html'
|
|
224
|
-
});
|
|
225
|
-
//console.log('pre complete bundlejs');
|
|
226
|
-
//console.log('res.length()', res.length());
|
|
227
|
-
complete(res);
|
|
228
|
-
}
|
|
229
|
-
});
|
|
230
|
-
*/
|
|
231
|
-
// Need to create a new control
|
|
232
|
-
//throw 'NYI';
|
|
233
|
-
}
|
|
234
|
-
} else {
|
|
235
|
-
throw 'NYI';
|
|
236
|
-
}
|
|
237
|
-
} else if (t_content === 'undefined') {
|
|
238
|
-
const html = `<html><head></head><body></body></html>`;
|
|
239
|
-
const buff = Buffer.from(html, "utf-8");
|
|
240
|
-
res.push({
|
|
241
|
-
'path': webpage.path,
|
|
242
|
-
'value': buff,
|
|
243
|
-
'content-type': 'text/html'
|
|
244
|
-
});
|
|
245
|
-
complete(res);
|
|
246
|
-
} else {
|
|
247
|
-
//console.log('t_content', t_content);
|
|
248
|
-
if (t_content === 'function') {
|
|
249
|
-
const spc = new Server_Page_Context({
|
|
250
|
-
//request:
|
|
251
|
-
});
|
|
252
|
-
const Ctrl = content;
|
|
253
|
-
const ctrl = new Ctrl({
|
|
254
|
-
'context': spc
|
|
255
|
-
});
|
|
256
|
-
if (ctrl instanceof HTML_Document) {
|
|
257
|
-
|
|
258
|
-
// Need way to fix this - it had been working OK before in some cases.
|
|
259
|
-
|
|
260
|
-
/*
|
|
261
|
-
|
|
262
|
-
console.log('ctrl', ctrl);
|
|
263
|
-
console.trace();
|
|
264
|
-
throw 'NYI - HTML_Document processing NYI';
|
|
265
|
-
*/
|
|
266
|
-
|
|
267
|
-
const buff_html = Buffer.from(ctrl.render(), "utf-8");
|
|
268
|
-
res.push({
|
|
269
|
-
'path': webpage.path,
|
|
270
|
-
'value': buff_html,
|
|
271
|
-
'content-type': 'text/html'
|
|
272
|
-
});
|
|
273
|
-
} else {
|
|
274
|
-
console.log('Bundle path A');
|
|
275
|
-
// is ctrl a Control instance?
|
|
276
|
-
// Is it a control in some other way?
|
|
277
|
-
|
|
278
|
-
if (ctrl instanceof Control || tof(ctrl) === 'control') {
|
|
279
|
-
const doc = new Client_HTML_Document({
|
|
280
|
-
context: spc
|
|
281
|
-
});
|
|
282
|
-
doc.include_js('/js/app.js');
|
|
283
|
-
doc.include_css('/css/app.css');
|
|
284
|
-
ctrl.active();
|
|
285
|
-
doc.body.add(ctrl);
|
|
286
|
-
const buff_html = Buffer.from(doc.html, "utf-8");
|
|
287
|
-
res.push({
|
|
288
|
-
'path': webpage.path,
|
|
289
|
-
'value': buff_html,
|
|
290
|
-
'content-type': 'text/html'
|
|
291
|
-
});
|
|
292
|
-
const diskpath_js_client = disk_path_client_js || require.resolve('jsgui3-html');
|
|
293
|
-
let waiting_for_css_extraction = false, handle_css_extraction_complete = undefined;
|
|
294
|
-
const obs_bundle = bundle_js(diskpath_js_client, {
|
|
295
|
-
'js_mode': 'debug',
|
|
296
|
-
'babel': 'debug'
|
|
297
|
-
});
|
|
298
|
-
obs_bundle.on('next', data => {
|
|
299
|
-
console.log('next Object.keys(data)', Object.keys(data));
|
|
300
|
-
const {lang, operation, compress, type, value} = data;
|
|
301
|
-
if (lang === 'JavaScript') {
|
|
302
|
-
if (type === 'single-string') {
|
|
303
|
-
|
|
304
|
-
// Get the CSS classes (as a JS object) from the JS file.
|
|
305
|
-
// Or get them as a CSS file stored in a buffer?
|
|
306
|
-
// Or maybe better they get returned as a 'Bundle' object.
|
|
307
|
-
|
|
308
|
-
const obs_css_from_js = bundle_css_from_js_str(value);
|
|
309
|
-
//console.log('post obs_css_from_js = bundle_css_from_js_str(value) call');
|
|
310
|
-
waiting_for_css_extraction = true;
|
|
311
|
-
obs_css_from_js.on('next', data => {
|
|
312
|
-
console.log('obs_css_from_js next data', data);
|
|
313
|
-
});
|
|
314
|
-
obs_css_from_js.on('complete', obs_css_from_js_res => {
|
|
315
|
-
console.log('obs_css_from_js complete obs_css_from_js_res', obs_css_from_js_res);
|
|
316
|
-
|
|
317
|
-
if (tof(obs_css_from_js_res) === 'string') {
|
|
318
|
-
const basic_and_app_css = Buffer.concat([o_basic_css.value, Buffer.from(obs_css_from_js_res)]);
|
|
319
|
-
res.push({
|
|
320
|
-
'path': webpage.path + 'css/app.css',
|
|
321
|
-
'value': basic_and_app_css,
|
|
322
|
-
'content-type': 'text/css'
|
|
323
|
-
});
|
|
324
|
-
waiting_for_css_extraction = false;
|
|
325
|
-
if (handle_css_extraction_complete) {
|
|
326
|
-
handle_css_extraction_complete();
|
|
327
|
-
} else {
|
|
328
|
-
console.trace();
|
|
329
|
-
throw 'stop';
|
|
330
|
-
}
|
|
331
|
-
}
|
|
332
|
-
});
|
|
333
|
-
}
|
|
334
|
-
}
|
|
335
|
-
})
|
|
336
|
-
|
|
337
|
-
obs_bundle.on('complete', res_bundle_js => {
|
|
338
|
-
const do_when_complete = () => {
|
|
339
|
-
console.log('js-bundler bundle is complete');
|
|
340
|
-
console.trace();
|
|
341
|
-
console.log('res_bundle_js', res_bundle_js);
|
|
342
|
-
console.log('res', res);
|
|
343
|
-
res.push({
|
|
344
|
-
'path': webpage.path + 'js/app.js',
|
|
345
|
-
'value': res_bundle_js,
|
|
346
|
-
'content-type': 'text/javascript'
|
|
347
|
-
});
|
|
348
|
-
//throw 'stop';
|
|
349
|
-
complete(res);
|
|
350
|
-
}
|
|
351
|
-
|
|
352
|
-
if (waiting_for_css_extraction) {
|
|
353
|
-
handle_css_extraction_complete = do_when_complete;
|
|
354
|
-
} else {
|
|
355
|
-
do_when_complete();
|
|
356
|
-
}
|
|
357
|
-
})
|
|
358
|
-
} else {
|
|
359
|
-
console.trace();
|
|
360
|
-
console.log('ctrl', ctrl);
|
|
361
|
-
throw 'NYI';
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
|
|
365
|
-
} else if (false) {
|
|
366
|
-
console.trace();
|
|
367
|
-
throw 'NYI';
|
|
368
|
-
} else {
|
|
369
|
-
console.log('t_content', t_content);
|
|
370
|
-
console.log('content', content);
|
|
371
|
-
console.trace();
|
|
372
|
-
throw 'NYI';
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
})().catch(err => {
|
|
376
|
-
console.trace();
|
|
377
|
-
console.log('err', err);
|
|
378
|
-
|
|
379
|
-
throw err;
|
|
380
|
-
//console.error(err);
|
|
381
|
-
});
|
|
382
|
-
|
|
383
|
-
// The observable could / should return updates along the way, things that contribute to the full result.
|
|
384
|
-
const stop = () => {throw 'NYI'};
|
|
385
|
-
const pause = () => {throw 'NYI'};
|
|
386
|
-
const resume = () => {throw 'NYI'};
|
|
387
|
-
|
|
388
|
-
return [stop, pause, resume];
|
|
389
|
-
|
|
390
|
-
});
|
|
391
|
-
//throw 'NYI';
|
|
392
|
-
}
|
|
393
|
-
|
|
394
|
-
class Webpage_Bundler extends Bundler {
|
|
395
|
-
constructor(spec = {}) {
|
|
396
|
-
super(spec);
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
Webpage_Bundler.bundle_web_page = bundle_web_page;
|
|
401
|
-
Webpage_Bundler.prototype.bundle_web_page = bundle_web_page;
|
|
402
|
-
Webpage_Bundler.prototype.bundle = bundle_web_page;
|
|
403
|
-
|
|
404
|
-
|
|
1
|
+
// Basically need to split things up into isolated and specific encapsulated pieces of functionality.
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
// Just need to make the appropriate class names and structures....
|
|
5
|
+
|
|
6
|
+
// And CSS from JS extraction.
|
|
7
|
+
// Maybe even JS from JS.
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
// Late 2023 - Looks best to retire this one, make it really flexible in terms of what it does internally, with (many?) more classes doing
|
|
11
|
+
// specific things. It looks like ESBuild is the fastest option, may need to mix that with some very specific pieces of functionality
|
|
12
|
+
// for things like splitting / extracting CSS.
|
|
13
|
+
|
|
14
|
+
// Will identify the various parts of the tasks involved in bundling (and then serving) assets on the web.
|
|
15
|
+
// Will make classes that are named 1st in terms of that they do, but then there will be directories with different implementations
|
|
16
|
+
// of that functionality.
|
|
17
|
+
|
|
18
|
+
// May well be worth having this link to (require and export) an improved and specific version of the Webpage_Bundler class.
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
const Bundler = require('./bundler');
|
|
26
|
+
|
|
27
|
+
const JS_Bundler = require('./js-bundler');
|
|
28
|
+
const CSS_Bundler = require('./css-bundler');
|
|
29
|
+
|
|
30
|
+
const {bundle_css_from_js_str, stream_html_basic_css} = CSS_Bundler;
|
|
31
|
+
|
|
32
|
+
const Bundle = require('./bundle');
|
|
33
|
+
const {obs, prom_or_cb} = require('fnl');
|
|
34
|
+
const fnlfs = require('fnlfs');
|
|
35
|
+
const {tof, HTML_Document, Client_HTML_Document, Control} = require('jsgui3-html');
|
|
36
|
+
const util = require('util');
|
|
37
|
+
const Server_Page_Context = require('../../../page-context');
|
|
38
|
+
// Will put the JS together. Maybe images?
|
|
39
|
+
// Get everything ready to serve.
|
|
40
|
+
//const browserify = require('browserify');
|
|
41
|
+
const babel = require('@babel/core');
|
|
42
|
+
const stream_to_array = require('stream-to-array');
|
|
43
|
+
|
|
44
|
+
const {bundle_js} = JS_Bundler;
|
|
45
|
+
// Observable to load the basic CSS, or return it.
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
// This may / will be another part of it.
|
|
49
|
+
// Or a specific analysis / css extraction part of the build.
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
const get_basic_css_content_obj = () => {
|
|
56
|
+
return obs((next, complete, error) => {
|
|
57
|
+
|
|
58
|
+
const s_css = stream_html_basic_css();
|
|
59
|
+
|
|
60
|
+
const chunks = [];
|
|
61
|
+
let buf_css;
|
|
62
|
+
|
|
63
|
+
s_css.once('end', () => {
|
|
64
|
+
// create the final data Buffer from data chunks;
|
|
65
|
+
buf_css = Buffer.concat(chunks);
|
|
66
|
+
complete({
|
|
67
|
+
'value': buf_css,
|
|
68
|
+
'content-type': 'text/css'
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
// Of course, you can do anything else you need to here, like emit an event!
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
// Data is flushed from fileStream in chunks,
|
|
75
|
+
// this callback will be executed for each chunk
|
|
76
|
+
s_css.on('data', (chunk) => {
|
|
77
|
+
chunks.push(chunk); // push data chunk to array
|
|
78
|
+
|
|
79
|
+
// We can perform actions on the partial data we have so far!
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
// /bundlers/webpage/babel-and-browserify
|
|
87
|
+
|
|
88
|
+
|
|
89
|
+
// Webpage_Bundler_Using_Babel_And_Browserify
|
|
90
|
+
// Webpage_Bundler_Using_ESBuild
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
// Multiple steps...
|
|
94
|
+
// Initial step of building to 1 js file, and also extracting other content from the JS, such as CSS.
|
|
95
|
+
// Possibly want to remove that CSS from the JS?
|
|
96
|
+
// Possibly want it in the CSS file rather than the JS.
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
|
|
100
|
+
// Interpret / compile (from) JS?
|
|
101
|
+
|
|
102
|
+
|
|
103
|
+
// Split JS to JS and CSS?
|
|
104
|
+
// And do that with the built (initially built) JS....
|
|
105
|
+
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
// Extract bundle pieces from... js file(s).
|
|
109
|
+
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
// Resource_Transformer???
|
|
113
|
+
|
|
114
|
+
// JS_To_JS????
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
|
|
119
|
+
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
|
|
123
|
+
|
|
124
|
+
|
|
125
|
+
|
|
126
|
+
|
|
127
|
+
const bundle_web_page = (webpage, options = {}) => {
|
|
128
|
+
|
|
129
|
+
|
|
130
|
+
// But we need specific bundlers that use specific tools internally.
|
|
131
|
+
|
|
132
|
+
|
|
133
|
+
|
|
134
|
+
// Nice here as an obs fn.
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
const {content} = webpage;
|
|
138
|
+
let {disk_path_client_js} = options;
|
|
139
|
+
|
|
140
|
+
const t_content = tof(content);
|
|
141
|
+
console.log('t_content', t_content);
|
|
142
|
+
|
|
143
|
+
return obs((next, complete, error) => {
|
|
144
|
+
const res = new Bundle();
|
|
145
|
+
(async () => {
|
|
146
|
+
const o_basic_css = await get_basic_css_content_obj();
|
|
147
|
+
if (t_content === 'string') {
|
|
148
|
+
const buff = Buffer.from(`<html><head><title>${webpage.title}</title></head><body>${content}</body></html>`, "utf-8");
|
|
149
|
+
res.push({
|
|
150
|
+
'path': webpage.path,
|
|
151
|
+
'value': buff,
|
|
152
|
+
'content-type': 'text/html'
|
|
153
|
+
});
|
|
154
|
+
complete(res);
|
|
155
|
+
} else if (t_content === 'control') {
|
|
156
|
+
if (content instanceof Control) {
|
|
157
|
+
//console.log('content is control');
|
|
158
|
+
//console.log('content.constructor.name', content.constructor.name);
|
|
159
|
+
if (content instanceof HTML_Document) {
|
|
160
|
+
console.log('content is an html document');
|
|
161
|
+
// May in fact be much easier.
|
|
162
|
+
// Assume already bundled?
|
|
163
|
+
// Probably best not to.
|
|
164
|
+
|
|
165
|
+
// Want to have nicely named functions that get called to do things.
|
|
166
|
+
|
|
167
|
+
|
|
168
|
+
|
|
169
|
+
throw 'NYI';
|
|
170
|
+
} else {
|
|
171
|
+
const diskpath_js_client = disk_path_client_js || require.resolve('jsgui3-html');
|
|
172
|
+
res_bundle_js = await bundle_js(diskpath_js_client, {
|
|
173
|
+
'js_mode': 'mini',
|
|
174
|
+
'babel': 'mini'
|
|
175
|
+
});
|
|
176
|
+
console.log('res_bundle_js', res_bundle_js);
|
|
177
|
+
throw 'NYI';
|
|
178
|
+
|
|
179
|
+
/*
|
|
180
|
+
|
|
181
|
+
bundle_js(diskpath_js_client, {
|
|
182
|
+
'js_mode': 'mini',
|
|
183
|
+
'babel': 'mini'
|
|
184
|
+
}, (err, res_bundle_js) => {
|
|
185
|
+
if (err) {
|
|
186
|
+
console.trace();
|
|
187
|
+
throw err;
|
|
188
|
+
} else {
|
|
189
|
+
//console.log('res_bundle_js', res_bundle_js);
|
|
190
|
+
|
|
191
|
+
// Could search at this point for class.css properties.
|
|
192
|
+
res.push({
|
|
193
|
+
'path': webpage.path + 'js/app.js',
|
|
194
|
+
'value': res_bundle_js,
|
|
195
|
+
'content-type': 'text/javascript'
|
|
196
|
+
});
|
|
197
|
+
|
|
198
|
+
const spc = new Server_Page_Context({
|
|
199
|
+
//request:
|
|
200
|
+
});
|
|
201
|
+
|
|
202
|
+
|
|
203
|
+
const doc = new Client_HTML_Document({
|
|
204
|
+
context: spc
|
|
205
|
+
});
|
|
206
|
+
doc.include_js('/js/app.js');
|
|
207
|
+
doc.body.add(content);
|
|
208
|
+
|
|
209
|
+
// Getting it to load the JS would be nice...
|
|
210
|
+
// But maybe only do it automatically if it's an active document.
|
|
211
|
+
// If it's just generated JS then best not to bundle JS to load.
|
|
212
|
+
|
|
213
|
+
// Could also make smaller bundles for some specific parts of the app. Could improve speed.
|
|
214
|
+
//console.log('doc.html', doc.html);
|
|
215
|
+
const buff_html = Buffer.from(doc.html, "utf-8");
|
|
216
|
+
// But add the client-side stuff to that doc.
|
|
217
|
+
|
|
218
|
+
// Remember, this part is about bundling rather than serving.
|
|
219
|
+
|
|
220
|
+
res.push({
|
|
221
|
+
'path': webpage.path,
|
|
222
|
+
'value': buff_html,
|
|
223
|
+
'content-type': 'text/html'
|
|
224
|
+
});
|
|
225
|
+
//console.log('pre complete bundlejs');
|
|
226
|
+
//console.log('res.length()', res.length());
|
|
227
|
+
complete(res);
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
*/
|
|
231
|
+
// Need to create a new control
|
|
232
|
+
//throw 'NYI';
|
|
233
|
+
}
|
|
234
|
+
} else {
|
|
235
|
+
throw 'NYI';
|
|
236
|
+
}
|
|
237
|
+
} else if (t_content === 'undefined') {
|
|
238
|
+
const html = `<html><head></head><body></body></html>`;
|
|
239
|
+
const buff = Buffer.from(html, "utf-8");
|
|
240
|
+
res.push({
|
|
241
|
+
'path': webpage.path,
|
|
242
|
+
'value': buff,
|
|
243
|
+
'content-type': 'text/html'
|
|
244
|
+
});
|
|
245
|
+
complete(res);
|
|
246
|
+
} else {
|
|
247
|
+
//console.log('t_content', t_content);
|
|
248
|
+
if (t_content === 'function') {
|
|
249
|
+
const spc = new Server_Page_Context({
|
|
250
|
+
//request:
|
|
251
|
+
});
|
|
252
|
+
const Ctrl = content;
|
|
253
|
+
const ctrl = new Ctrl({
|
|
254
|
+
'context': spc
|
|
255
|
+
});
|
|
256
|
+
if (ctrl instanceof HTML_Document) {
|
|
257
|
+
|
|
258
|
+
// Need way to fix this - it had been working OK before in some cases.
|
|
259
|
+
|
|
260
|
+
/*
|
|
261
|
+
|
|
262
|
+
console.log('ctrl', ctrl);
|
|
263
|
+
console.trace();
|
|
264
|
+
throw 'NYI - HTML_Document processing NYI';
|
|
265
|
+
*/
|
|
266
|
+
|
|
267
|
+
const buff_html = Buffer.from(ctrl.render(), "utf-8");
|
|
268
|
+
res.push({
|
|
269
|
+
'path': webpage.path,
|
|
270
|
+
'value': buff_html,
|
|
271
|
+
'content-type': 'text/html'
|
|
272
|
+
});
|
|
273
|
+
} else {
|
|
274
|
+
console.log('Bundle path A');
|
|
275
|
+
// is ctrl a Control instance?
|
|
276
|
+
// Is it a control in some other way?
|
|
277
|
+
|
|
278
|
+
if (ctrl instanceof Control || tof(ctrl) === 'control') {
|
|
279
|
+
const doc = new Client_HTML_Document({
|
|
280
|
+
context: spc
|
|
281
|
+
});
|
|
282
|
+
doc.include_js('/js/app.js');
|
|
283
|
+
doc.include_css('/css/app.css');
|
|
284
|
+
ctrl.active();
|
|
285
|
+
doc.body.add(ctrl);
|
|
286
|
+
const buff_html = Buffer.from(doc.html, "utf-8");
|
|
287
|
+
res.push({
|
|
288
|
+
'path': webpage.path,
|
|
289
|
+
'value': buff_html,
|
|
290
|
+
'content-type': 'text/html'
|
|
291
|
+
});
|
|
292
|
+
const diskpath_js_client = disk_path_client_js || require.resolve('jsgui3-html');
|
|
293
|
+
let waiting_for_css_extraction = false, handle_css_extraction_complete = undefined;
|
|
294
|
+
const obs_bundle = bundle_js(diskpath_js_client, {
|
|
295
|
+
'js_mode': 'debug',
|
|
296
|
+
'babel': 'debug'
|
|
297
|
+
});
|
|
298
|
+
obs_bundle.on('next', data => {
|
|
299
|
+
console.log('next Object.keys(data)', Object.keys(data));
|
|
300
|
+
const {lang, operation, compress, type, value} = data;
|
|
301
|
+
if (lang === 'JavaScript') {
|
|
302
|
+
if (type === 'single-string') {
|
|
303
|
+
|
|
304
|
+
// Get the CSS classes (as a JS object) from the JS file.
|
|
305
|
+
// Or get them as a CSS file stored in a buffer?
|
|
306
|
+
// Or maybe better they get returned as a 'Bundle' object.
|
|
307
|
+
|
|
308
|
+
const obs_css_from_js = bundle_css_from_js_str(value);
|
|
309
|
+
//console.log('post obs_css_from_js = bundle_css_from_js_str(value) call');
|
|
310
|
+
waiting_for_css_extraction = true;
|
|
311
|
+
obs_css_from_js.on('next', data => {
|
|
312
|
+
console.log('obs_css_from_js next data', data);
|
|
313
|
+
});
|
|
314
|
+
obs_css_from_js.on('complete', obs_css_from_js_res => {
|
|
315
|
+
console.log('obs_css_from_js complete obs_css_from_js_res', obs_css_from_js_res);
|
|
316
|
+
|
|
317
|
+
if (tof(obs_css_from_js_res) === 'string') {
|
|
318
|
+
const basic_and_app_css = Buffer.concat([o_basic_css.value, Buffer.from(obs_css_from_js_res)]);
|
|
319
|
+
res.push({
|
|
320
|
+
'path': webpage.path + 'css/app.css',
|
|
321
|
+
'value': basic_and_app_css,
|
|
322
|
+
'content-type': 'text/css'
|
|
323
|
+
});
|
|
324
|
+
waiting_for_css_extraction = false;
|
|
325
|
+
if (handle_css_extraction_complete) {
|
|
326
|
+
handle_css_extraction_complete();
|
|
327
|
+
} else {
|
|
328
|
+
console.trace();
|
|
329
|
+
throw 'stop';
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
})
|
|
336
|
+
|
|
337
|
+
obs_bundle.on('complete', res_bundle_js => {
|
|
338
|
+
const do_when_complete = () => {
|
|
339
|
+
console.log('js-bundler bundle is complete');
|
|
340
|
+
console.trace();
|
|
341
|
+
console.log('res_bundle_js', res_bundle_js);
|
|
342
|
+
console.log('res', res);
|
|
343
|
+
res.push({
|
|
344
|
+
'path': webpage.path + 'js/app.js',
|
|
345
|
+
'value': res_bundle_js,
|
|
346
|
+
'content-type': 'text/javascript'
|
|
347
|
+
});
|
|
348
|
+
//throw 'stop';
|
|
349
|
+
complete(res);
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
if (waiting_for_css_extraction) {
|
|
353
|
+
handle_css_extraction_complete = do_when_complete;
|
|
354
|
+
} else {
|
|
355
|
+
do_when_complete();
|
|
356
|
+
}
|
|
357
|
+
})
|
|
358
|
+
} else {
|
|
359
|
+
console.trace();
|
|
360
|
+
console.log('ctrl', ctrl);
|
|
361
|
+
throw 'NYI';
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
} else if (false) {
|
|
366
|
+
console.trace();
|
|
367
|
+
throw 'NYI';
|
|
368
|
+
} else {
|
|
369
|
+
console.log('t_content', t_content);
|
|
370
|
+
console.log('content', content);
|
|
371
|
+
console.trace();
|
|
372
|
+
throw 'NYI';
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
})().catch(err => {
|
|
376
|
+
console.trace();
|
|
377
|
+
console.log('err', err);
|
|
378
|
+
|
|
379
|
+
throw err;
|
|
380
|
+
//console.error(err);
|
|
381
|
+
});
|
|
382
|
+
|
|
383
|
+
// The observable could / should return updates along the way, things that contribute to the full result.
|
|
384
|
+
const stop = () => {throw 'NYI'};
|
|
385
|
+
const pause = () => {throw 'NYI'};
|
|
386
|
+
const resume = () => {throw 'NYI'};
|
|
387
|
+
|
|
388
|
+
return [stop, pause, resume];
|
|
389
|
+
|
|
390
|
+
});
|
|
391
|
+
//throw 'NYI';
|
|
392
|
+
}
|
|
393
|
+
|
|
394
|
+
class Webpage_Bundler extends Bundler {
|
|
395
|
+
constructor(spec = {}) {
|
|
396
|
+
super(spec);
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
Webpage_Bundler.bundle_web_page = bundle_web_page;
|
|
401
|
+
Webpage_Bundler.prototype.bundle_web_page = bundle_web_page;
|
|
402
|
+
Webpage_Bundler.prototype.bundle = bundle_web_page;
|
|
403
|
+
|
|
404
|
+
|
|
405
405
|
module.exports = Webpage_Bundler;
|