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,264 +1,264 @@
|
|
|
1
|
-
// Bundler could be moved to with resource / resource processor / publisher.
|
|
2
|
-
// Maybe a bunder is a type of resource publisher or should be used by it.
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const all_old_bundler_implementation = () => {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
const Bundler = require('./bundler');
|
|
10
|
-
const Bundle = require('./bundle');
|
|
11
|
-
const {obs, prom_or_cb} = require('fnl');
|
|
12
|
-
const {tof} = require('jsgui3-html');
|
|
13
|
-
const fnlfs = require('fnlfs');
|
|
14
|
-
|
|
15
|
-
// May want a more base JS_Bundler class, and then subclasses will use specific modules like Babel or ESBuild to bundle.
|
|
16
|
-
// That way can go for nice defaults and provide flexibility too. Plus interchangability of some inner components, eg if someone
|
|
17
|
-
//
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
//const browserify = require('browserify');
|
|
22
|
-
const babel = require('@babel/core');
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const stream_to_array = require('stream-to-array');
|
|
26
|
-
const util = require('util');
|
|
27
|
-
const Stream = require('stream');
|
|
28
|
-
// Will put the JS together. Maybe images?
|
|
29
|
-
|
|
30
|
-
// Will put the JS together. Maybe images?
|
|
31
|
-
// Get everything ready to serve.
|
|
32
|
-
|
|
33
|
-
// Would need a JS file that contains refs to all of the components used.
|
|
34
|
-
// Examine what is in the website and what JS it needs.
|
|
35
|
-
|
|
36
|
-
// Should be customisable which system gets used to make the bundle.
|
|
37
|
-
// eg babel or esbuild. Browserify still seems to work on code here at least, but esbuild seems better.
|
|
38
|
-
|
|
39
|
-
// JS bundling will become a bit more advanced in this server. Similar principles.
|
|
40
|
-
|
|
41
|
-
// JS_Bundler reporting css that gets found while bundling JS would make sense.
|
|
42
|
-
|
|
43
|
-
// jsgui3-jsbuilder could be a separate project too.
|
|
44
|
-
// or jsgui3-js-builder even.
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
// A JS Bundler or JS Packager class will probably be best.
|
|
50
|
-
|
|
51
|
-
// This seems more like a babel specific JS Bundler.
|
|
52
|
-
// Or even compiler???
|
|
53
|
-
// Source_Compiler????
|
|
54
|
-
|
|
55
|
-
// Giving the classes simple and intuitive APIs, allowing for them to be nicely interchangable.
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
const bundle_js = (js_file_path, options = {}, callback) => {
|
|
64
|
-
|
|
65
|
-
// Could even split a file into its server and client components.
|
|
66
|
-
// Maybe providing found css would work well here.
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
// Returning an observable and not using a callback would work best.
|
|
71
|
-
|
|
72
|
-
const res = obs((next, complete, error) => {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
let a = arguments;
|
|
77
|
-
if (typeof a[2] === 'function') {
|
|
78
|
-
callback = a[2];
|
|
79
|
-
|
|
80
|
-
options.include_sourcemaps = true;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
(async () => {
|
|
84
|
-
// options
|
|
85
|
-
// may want a replacement within the client-side code.
|
|
86
|
-
// Can we call browserify on the code string?
|
|
87
|
-
// Creating a modified copy of the file would do.
|
|
88
|
-
// Load the file, modify it, save it under a different name
|
|
89
|
-
|
|
90
|
-
let s = new Stream.Readable(),
|
|
91
|
-
path = require('path').parse(js_file_path);
|
|
92
|
-
|
|
93
|
-
let fileContents = await fnlfs.load(js_file_path);
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
// Maybe do that post browserify - can read through whole thing to find the css template literals.
|
|
97
|
-
|
|
98
|
-
// Could use the CSS bundler to scan_js_for_css
|
|
99
|
-
// Seems as though it would be best as an observable.
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
// Could first get own system AST of the JS file.
|
|
103
|
-
|
|
104
|
-
// Modify the original file contents so that only client-side parts appear?
|
|
105
|
-
// Could be done by programatically removing a whole code block, what to do if it is run on the server.
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
//console.log('1) fileContents.length', fileContents.length);
|
|
109
|
-
// are there any replacements to do?
|
|
110
|
-
// options.replacements
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
if (options.js_mode === 'debug') {
|
|
115
|
-
options.include_sourcemaps = true;
|
|
116
|
-
}
|
|
117
|
-
if (options.js_mode === 'compress' || options.js_mode === 'mini') {
|
|
118
|
-
options.include_sourcemaps = false;
|
|
119
|
-
options.babel = 'mini';
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
//console.log('options.babel', options.babel);
|
|
123
|
-
|
|
124
|
-
if (options.replace) {
|
|
125
|
-
let s_file_contents = fileContents.toString();
|
|
126
|
-
//console.log('s_file_contents', s_file_contents);
|
|
127
|
-
each(options.replace, (text, key) => {
|
|
128
|
-
//console.log('key', key);
|
|
129
|
-
//console.log('text', text);
|
|
130
|
-
let running_fn = '(' + text + ')();'
|
|
131
|
-
//console.log('running_fn', running_fn);
|
|
132
|
-
s_file_contents = s_file_contents.split(key).join(running_fn);
|
|
133
|
-
})
|
|
134
|
-
fileContents = Buffer.from(s_file_contents);
|
|
135
|
-
//console.log('2) fileContents.length', fileContents.length);
|
|
136
|
-
}
|
|
137
|
-
// Then we can replace some of the file contents with specific content given when we tall it to serve that file.
|
|
138
|
-
// We have a space for client-side activation.
|
|
139
|
-
s.push(fileContents);
|
|
140
|
-
s.push(null);
|
|
141
|
-
|
|
142
|
-
//let include_sourcemaps = true;
|
|
143
|
-
|
|
144
|
-
let b = browserify(s, {
|
|
145
|
-
basedir: path.dir,
|
|
146
|
-
//builtins: false,
|
|
147
|
-
builtins: ['buffer', 'process'],
|
|
148
|
-
'debug': options.include_sourcemaps
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
// May be able to better put the bundle stream info into the observable results.
|
|
152
|
-
// Browserify gets given the stream.
|
|
153
|
-
|
|
154
|
-
// Nice if this function could output a stream as well.
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
let parts = await stream_to_array(b.bundle());
|
|
158
|
-
|
|
159
|
-
const buffers = parts
|
|
160
|
-
.map(part => util.isBuffer(part) ? part : Buffer.from(part));
|
|
161
|
-
let buf_js = Buffer.concat(buffers);
|
|
162
|
-
let str_js = buf_js.toString();
|
|
163
|
-
|
|
164
|
-
next({
|
|
165
|
-
'lang': 'JavaScript',
|
|
166
|
-
'operation': 'bundle',
|
|
167
|
-
'compress': false,
|
|
168
|
-
'type': 'single-string',
|
|
169
|
-
'value': str_js
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
// full browserified (client) js app.
|
|
173
|
-
|
|
174
|
-
let babel_option = options.babel
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
// could send str_js to a CSS extractor / bundler.
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
//console.log('babel_option', babel_option);
|
|
181
|
-
if (babel_option === 'es5') {
|
|
182
|
-
|
|
183
|
-
let o_transform = {
|
|
184
|
-
"presets": [
|
|
185
|
-
"es2015",
|
|
186
|
-
"es2017"
|
|
187
|
-
],
|
|
188
|
-
"plugins": [
|
|
189
|
-
"transform-runtime"
|
|
190
|
-
] //,
|
|
191
|
-
//'sourceMaps': 'inline'
|
|
192
|
-
};
|
|
193
|
-
|
|
194
|
-
if (options.include_sourcemaps) o_transform.sourceMaps = 'inline';
|
|
195
|
-
let res_transform = babel.transform(str_js, o_transform);
|
|
196
|
-
//console.log('res_transform', res_transform);
|
|
197
|
-
//console.log('Object.keys(res_transform)', Object.keys(res_transform));
|
|
198
|
-
let jst_es5 = res_transform.code;
|
|
199
|
-
//let {jst_es5, map, ast} = babel.transform(str_js);
|
|
200
|
-
//console.log('jst_es5.length', jst_es5.length);
|
|
201
|
-
buf_js = Buffer.from(jst_es5);
|
|
202
|
-
} else if (babel_option === 'mini') {
|
|
203
|
-
/*
|
|
204
|
-
let o_transform = {
|
|
205
|
-
presets: ["minify"]//,
|
|
206
|
-
//'sourceMaps': 'inline'
|
|
207
|
-
};
|
|
208
|
-
*/
|
|
209
|
-
let o_transform = {
|
|
210
|
-
"presets": [
|
|
211
|
-
["minify", {
|
|
212
|
-
//"mangle": {
|
|
213
|
-
//"exclude": ["MyCustomError"]
|
|
214
|
-
//},
|
|
215
|
-
//"unsafe": {
|
|
216
|
-
// "typeConstructors": false
|
|
217
|
-
//},
|
|
218
|
-
//"keepFnName": true
|
|
219
|
-
}]
|
|
220
|
-
],
|
|
221
|
-
//plugins: ["minify-dead-code-elimination"]
|
|
222
|
-
};
|
|
223
|
-
if (options.include_sourcemaps) o_transform.sourceMaps = 'inline';
|
|
224
|
-
let res_transform = babel.transform(str_js, o_transform);
|
|
225
|
-
buf_js = Buffer.from(res_transform.code);
|
|
226
|
-
} else {
|
|
227
|
-
buf_js = Buffer.from(str_js);
|
|
228
|
-
}
|
|
229
|
-
complete(buf_js);
|
|
230
|
-
})();
|
|
231
|
-
|
|
232
|
-
})
|
|
233
|
-
if (callback) {
|
|
234
|
-
res.on('complete', (value) => {
|
|
235
|
-
callback(null, value);
|
|
236
|
-
});
|
|
237
|
-
res.on('error', err => {
|
|
238
|
-
callback(err);
|
|
239
|
-
})
|
|
240
|
-
} else {
|
|
241
|
-
return res;
|
|
242
|
-
}
|
|
243
|
-
// An observable would be better as result could include status messages (with their timings).
|
|
244
|
-
|
|
245
|
-
//return prom_or_cb((resolve, reject) => {
|
|
246
|
-
|
|
247
|
-
//}, callback);
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
class JS_Bundler extends Bundler {
|
|
251
|
-
constructor(spec = {}) {
|
|
252
|
-
super(spec);
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
JS_Bundler.bundle_js = bundle_js;
|
|
257
|
-
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
const JS_Bundler = require('./js/JS_Bundler');
|
|
262
|
-
|
|
263
|
-
|
|
1
|
+
// Bundler could be moved to with resource / resource processor / publisher.
|
|
2
|
+
// Maybe a bunder is a type of resource publisher or should be used by it.
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
const all_old_bundler_implementation = () => {
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
const Bundler = require('./bundler');
|
|
10
|
+
const Bundle = require('./bundle');
|
|
11
|
+
const {obs, prom_or_cb} = require('fnl');
|
|
12
|
+
const {tof} = require('jsgui3-html');
|
|
13
|
+
const fnlfs = require('fnlfs');
|
|
14
|
+
|
|
15
|
+
// May want a more base JS_Bundler class, and then subclasses will use specific modules like Babel or ESBuild to bundle.
|
|
16
|
+
// That way can go for nice defaults and provide flexibility too. Plus interchangability of some inner components, eg if someone
|
|
17
|
+
//
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
//const browserify = require('browserify');
|
|
22
|
+
const babel = require('@babel/core');
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
const stream_to_array = require('stream-to-array');
|
|
26
|
+
const util = require('util');
|
|
27
|
+
const Stream = require('stream');
|
|
28
|
+
// Will put the JS together. Maybe images?
|
|
29
|
+
|
|
30
|
+
// Will put the JS together. Maybe images?
|
|
31
|
+
// Get everything ready to serve.
|
|
32
|
+
|
|
33
|
+
// Would need a JS file that contains refs to all of the components used.
|
|
34
|
+
// Examine what is in the website and what JS it needs.
|
|
35
|
+
|
|
36
|
+
// Should be customisable which system gets used to make the bundle.
|
|
37
|
+
// eg babel or esbuild. Browserify still seems to work on code here at least, but esbuild seems better.
|
|
38
|
+
|
|
39
|
+
// JS bundling will become a bit more advanced in this server. Similar principles.
|
|
40
|
+
|
|
41
|
+
// JS_Bundler reporting css that gets found while bundling JS would make sense.
|
|
42
|
+
|
|
43
|
+
// jsgui3-jsbuilder could be a separate project too.
|
|
44
|
+
// or jsgui3-js-builder even.
|
|
45
|
+
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
|
|
49
|
+
// A JS Bundler or JS Packager class will probably be best.
|
|
50
|
+
|
|
51
|
+
// This seems more like a babel specific JS Bundler.
|
|
52
|
+
// Or even compiler???
|
|
53
|
+
// Source_Compiler????
|
|
54
|
+
|
|
55
|
+
// Giving the classes simple and intuitive APIs, allowing for them to be nicely interchangable.
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
const bundle_js = (js_file_path, options = {}, callback) => {
|
|
64
|
+
|
|
65
|
+
// Could even split a file into its server and client components.
|
|
66
|
+
// Maybe providing found css would work well here.
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
// Returning an observable and not using a callback would work best.
|
|
71
|
+
|
|
72
|
+
const res = obs((next, complete, error) => {
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
let a = arguments;
|
|
77
|
+
if (typeof a[2] === 'function') {
|
|
78
|
+
callback = a[2];
|
|
79
|
+
|
|
80
|
+
options.include_sourcemaps = true;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
(async () => {
|
|
84
|
+
// options
|
|
85
|
+
// may want a replacement within the client-side code.
|
|
86
|
+
// Can we call browserify on the code string?
|
|
87
|
+
// Creating a modified copy of the file would do.
|
|
88
|
+
// Load the file, modify it, save it under a different name
|
|
89
|
+
|
|
90
|
+
let s = new Stream.Readable(),
|
|
91
|
+
path = require('path').parse(js_file_path);
|
|
92
|
+
|
|
93
|
+
let fileContents = await fnlfs.load(js_file_path);
|
|
94
|
+
|
|
95
|
+
|
|
96
|
+
// Maybe do that post browserify - can read through whole thing to find the css template literals.
|
|
97
|
+
|
|
98
|
+
// Could use the CSS bundler to scan_js_for_css
|
|
99
|
+
// Seems as though it would be best as an observable.
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
// Could first get own system AST of the JS file.
|
|
103
|
+
|
|
104
|
+
// Modify the original file contents so that only client-side parts appear?
|
|
105
|
+
// Could be done by programatically removing a whole code block, what to do if it is run on the server.
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
//console.log('1) fileContents.length', fileContents.length);
|
|
109
|
+
// are there any replacements to do?
|
|
110
|
+
// options.replacements
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
if (options.js_mode === 'debug') {
|
|
115
|
+
options.include_sourcemaps = true;
|
|
116
|
+
}
|
|
117
|
+
if (options.js_mode === 'compress' || options.js_mode === 'mini') {
|
|
118
|
+
options.include_sourcemaps = false;
|
|
119
|
+
options.babel = 'mini';
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
//console.log('options.babel', options.babel);
|
|
123
|
+
|
|
124
|
+
if (options.replace) {
|
|
125
|
+
let s_file_contents = fileContents.toString();
|
|
126
|
+
//console.log('s_file_contents', s_file_contents);
|
|
127
|
+
each(options.replace, (text, key) => {
|
|
128
|
+
//console.log('key', key);
|
|
129
|
+
//console.log('text', text);
|
|
130
|
+
let running_fn = '(' + text + ')();'
|
|
131
|
+
//console.log('running_fn', running_fn);
|
|
132
|
+
s_file_contents = s_file_contents.split(key).join(running_fn);
|
|
133
|
+
})
|
|
134
|
+
fileContents = Buffer.from(s_file_contents);
|
|
135
|
+
//console.log('2) fileContents.length', fileContents.length);
|
|
136
|
+
}
|
|
137
|
+
// Then we can replace some of the file contents with specific content given when we tall it to serve that file.
|
|
138
|
+
// We have a space for client-side activation.
|
|
139
|
+
s.push(fileContents);
|
|
140
|
+
s.push(null);
|
|
141
|
+
|
|
142
|
+
//let include_sourcemaps = true;
|
|
143
|
+
|
|
144
|
+
let b = browserify(s, {
|
|
145
|
+
basedir: path.dir,
|
|
146
|
+
//builtins: false,
|
|
147
|
+
builtins: ['buffer', 'process'],
|
|
148
|
+
'debug': options.include_sourcemaps
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
// May be able to better put the bundle stream info into the observable results.
|
|
152
|
+
// Browserify gets given the stream.
|
|
153
|
+
|
|
154
|
+
// Nice if this function could output a stream as well.
|
|
155
|
+
|
|
156
|
+
|
|
157
|
+
let parts = await stream_to_array(b.bundle());
|
|
158
|
+
|
|
159
|
+
const buffers = parts
|
|
160
|
+
.map(part => util.isBuffer(part) ? part : Buffer.from(part));
|
|
161
|
+
let buf_js = Buffer.concat(buffers);
|
|
162
|
+
let str_js = buf_js.toString();
|
|
163
|
+
|
|
164
|
+
next({
|
|
165
|
+
'lang': 'JavaScript',
|
|
166
|
+
'operation': 'bundle',
|
|
167
|
+
'compress': false,
|
|
168
|
+
'type': 'single-string',
|
|
169
|
+
'value': str_js
|
|
170
|
+
});
|
|
171
|
+
|
|
172
|
+
// full browserified (client) js app.
|
|
173
|
+
|
|
174
|
+
let babel_option = options.babel
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
// could send str_js to a CSS extractor / bundler.
|
|
178
|
+
|
|
179
|
+
|
|
180
|
+
//console.log('babel_option', babel_option);
|
|
181
|
+
if (babel_option === 'es5') {
|
|
182
|
+
|
|
183
|
+
let o_transform = {
|
|
184
|
+
"presets": [
|
|
185
|
+
"es2015",
|
|
186
|
+
"es2017"
|
|
187
|
+
],
|
|
188
|
+
"plugins": [
|
|
189
|
+
"transform-runtime"
|
|
190
|
+
] //,
|
|
191
|
+
//'sourceMaps': 'inline'
|
|
192
|
+
};
|
|
193
|
+
|
|
194
|
+
if (options.include_sourcemaps) o_transform.sourceMaps = 'inline';
|
|
195
|
+
let res_transform = babel.transform(str_js, o_transform);
|
|
196
|
+
//console.log('res_transform', res_transform);
|
|
197
|
+
//console.log('Object.keys(res_transform)', Object.keys(res_transform));
|
|
198
|
+
let jst_es5 = res_transform.code;
|
|
199
|
+
//let {jst_es5, map, ast} = babel.transform(str_js);
|
|
200
|
+
//console.log('jst_es5.length', jst_es5.length);
|
|
201
|
+
buf_js = Buffer.from(jst_es5);
|
|
202
|
+
} else if (babel_option === 'mini') {
|
|
203
|
+
/*
|
|
204
|
+
let o_transform = {
|
|
205
|
+
presets: ["minify"]//,
|
|
206
|
+
//'sourceMaps': 'inline'
|
|
207
|
+
};
|
|
208
|
+
*/
|
|
209
|
+
let o_transform = {
|
|
210
|
+
"presets": [
|
|
211
|
+
["minify", {
|
|
212
|
+
//"mangle": {
|
|
213
|
+
//"exclude": ["MyCustomError"]
|
|
214
|
+
//},
|
|
215
|
+
//"unsafe": {
|
|
216
|
+
// "typeConstructors": false
|
|
217
|
+
//},
|
|
218
|
+
//"keepFnName": true
|
|
219
|
+
}]
|
|
220
|
+
],
|
|
221
|
+
//plugins: ["minify-dead-code-elimination"]
|
|
222
|
+
};
|
|
223
|
+
if (options.include_sourcemaps) o_transform.sourceMaps = 'inline';
|
|
224
|
+
let res_transform = babel.transform(str_js, o_transform);
|
|
225
|
+
buf_js = Buffer.from(res_transform.code);
|
|
226
|
+
} else {
|
|
227
|
+
buf_js = Buffer.from(str_js);
|
|
228
|
+
}
|
|
229
|
+
complete(buf_js);
|
|
230
|
+
})();
|
|
231
|
+
|
|
232
|
+
})
|
|
233
|
+
if (callback) {
|
|
234
|
+
res.on('complete', (value) => {
|
|
235
|
+
callback(null, value);
|
|
236
|
+
});
|
|
237
|
+
res.on('error', err => {
|
|
238
|
+
callback(err);
|
|
239
|
+
})
|
|
240
|
+
} else {
|
|
241
|
+
return res;
|
|
242
|
+
}
|
|
243
|
+
// An observable would be better as result could include status messages (with their timings).
|
|
244
|
+
|
|
245
|
+
//return prom_or_cb((resolve, reject) => {
|
|
246
|
+
|
|
247
|
+
//}, callback);
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
class JS_Bundler extends Bundler {
|
|
251
|
+
constructor(spec = {}) {
|
|
252
|
+
super(spec);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
JS_Bundler.bundle_js = bundle_js;
|
|
257
|
+
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
|
|
261
|
+
const JS_Bundler = require('./js/JS_Bundler');
|
|
262
|
+
|
|
263
|
+
|
|
264
264
|
module.exports = JS_Bundler;
|