jsgui3-server 0.0.81 → 0.0.84

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 (58) hide show
  1. package/README.md +8 -1
  2. package/bundler/bundle.js +11 -0
  3. package/bundler/bundler.js +9 -0
  4. package/bundler/css-bundler.js +48 -0
  5. package/bundler/js-bundler.js +205 -0
  6. package/bundler/test_ast.js +74 -0
  7. package/bundler/webpage-bundler.js +284 -0
  8. package/bundler/website-bundler.js +23 -0
  9. package/controls/README.md +8 -0
  10. package/controls/page/admin.js +75 -0
  11. package/controls/panel/admin.js +11 -0
  12. package/examples/controls/html-server-combo-box.js +5 -5
  13. package/examples/html-server.js +3 -0
  14. package/examples/square_box.js +35 -0
  15. package/examples/square_box_client.js +91 -0
  16. package/module.js +8 -0
  17. package/{single-control-server.js → old/_single-control-server.js} +157 -96
  18. package/old/single-control-server.js +108 -158
  19. package/{single-page-app.js → old/single-page-app.js} +2 -0
  20. package/{examples/demos → old}/square_box.js +1 -1
  21. package/package.json +9 -9
  22. package/page-context.js +1 -1
  23. package/publishing/http-css-publisher.js +0 -0
  24. package/publishing/{function-publisher.js → http-function-publisher.js} +12 -2
  25. package/publishing/http-html-page-publisher.js +5 -0
  26. package/publishing/http-html-publisher.js +25 -0
  27. package/publishing/http-jpeg-publisher.js +0 -0
  28. package/publishing/http-js-publisher.js +25 -0
  29. package/publishing/{observable-publisher.js → http-observable-publisher.js} +12 -6
  30. package/publishing/http-png-publisher.js +0 -0
  31. package/publishing/http-publisher.js +52 -0
  32. package/publishing/{resource-publisher.js → http-resource-publisher.js} +20 -1
  33. package/publishing/http-svg-publisher.js +0 -0
  34. package/publishing/http-webpage-publisher.js +112 -0
  35. package/publishing/http-website-publisher.js +254 -0
  36. package/publishing/notes.md +1 -0
  37. package/resources/README.md +16 -0
  38. package/resources/_old_website-resource.js +507 -0
  39. package/resources/compile/server-resource-compilation.js +41 -0
  40. package/resources/data-resource.js +14 -0
  41. package/resources/fs-resource.js +2 -4
  42. package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +3 -0
  43. package/resources/jsbuilder/test/test_ast_node.js +1 -1
  44. package/resources/jsbuilder/test/test_js_file.js +2 -2
  45. package/resources/jsbuilder/test/test_project.js +1 -0
  46. package/resources/notes.txt +11 -0
  47. package/resources/server-installed-tools.js +29 -0
  48. package/resources/server-resource-pool.js +1 -44
  49. package/resources/website-css-resource.js +1 -1
  50. package/resources/website-javascript-resource.js +165 -34
  51. package/resources/website-resource.js +62 -294
  52. package/resources/website-static-html-resource.js +8 -16
  53. package/resources/website-template-html-resource.js +231 -0
  54. package/roadmap.md +64 -0
  55. package/server.js +721 -18
  56. package/website/webpage.js +169 -0
  57. package/website/website-group.js +16 -0
  58. package/website/website.js +227 -0
@@ -0,0 +1,507 @@
1
+ /**
2
+ * Created by James on 29/07/2014.
3
+ */
4
+
5
+ // 2022 - Seems a little uncertain about what it is for, and what it does has grown over time.
6
+
7
+
8
+
9
+ // A Website abstraction and a Website_Publisher seem like a good way forward.
10
+
11
+
12
+ // Want to make a near future release have a web publishing system that is easier to use as well as more
13
+ // powerful.
14
+
15
+ // Publishing static sites, rendering and compiling.
16
+
17
+ // Represents (and is?) a website itself, and its representation available through the Resource system.
18
+
19
+
20
+ // Want to get the core resources working and tested.
21
+ // Want to run a clock website / service to start with.
22
+ // The server could have a clock, while clients could connect to it and share the information.
23
+ // Could also experiment with P2P distribution of the data.
24
+ // A clock is also useful because it contains time signals so we can see how long it takes for data to reach various machines.
25
+
26
+ // A web resource in particular?
27
+ // Any need for an HTML resource?
28
+ // Probably not - have web resource handle HTML and websockets.
29
+
30
+ // Resources could also have events which objects can listen to.
31
+ // Programmatic objects can listen.
32
+ // The resources may broadcast to whatever is listening.
33
+
34
+ // Also, maintaining one connection stream, communicating with multiple resources - could connect through a Resource Pool, or maybe there
35
+ // could be a Multi Resource Publisher that publishes a bunch of resources.
36
+
37
+ // The Application router at the moment sending requests to resources.
38
+ // I am thinking that rather than doing that, the requests should be handled by a resource publisher that interacts with the resource and publishes it over HTTP.
39
+
40
+ // Resources in general won't handle HTTP requests, though they will have the capability.
41
+ // More likely that a resource, when it is served online, will be served using a Resource Publisher (which is itself a resource), which handles HTTP implementation details that would otherwise have
42
+ // to be repeated between resources.
43
+
44
+ //define(["./jsgui-lang-util", './abstract-resource'], function(jsgui, AR) {
45
+
46
+ // Do this not with AMD?
47
+
48
+ // May need Website_Data_Resource
49
+ // Would be configured within the node app, client has maximum autoconfig from connecting to the server, and integration with client-side controls.
50
+ // With the DB admin, it's about returining queries (maybe from RAM) about table data.
51
+ // /data/then the api?
52
+
53
+ // Respond to both data HTTP requests and websocket connections.
54
+
55
+ // HTTP data request -> response seems like the most important step now.
56
+
57
+ // An fs Resource would be of use for file system browser.
58
+ // Could have a client-side fs resource that connects to a veriety of services, could have one that connects to the server-side fs resource.
59
+
60
+ // Need to connect a data-providing resource to the UI component in cases where it's not secure to do so automatically.
61
+ // It would be much more secure to bring up an NTP provision service automatically than a file system one. Don't want to take that risk now.
62
+ //
63
+
64
+ // Possibly WebPack could be considered such a resource? Or find a different type for that type of resource?
65
+
66
+ // Compilation_Resource and Compiler_Resource...
67
+
68
+
69
+ // Maybe should do more to represent a website on a server.
70
+ // Maybe it needs more docs, being rather critical.
71
+
72
+
73
+
74
+
75
+ var Site_Images = require("./website-image-resource");
76
+
77
+ //console.log('1) Site_Images', Site_Images);
78
+
79
+ var jsgui = require("jsgui3-html");
80
+ const { each, get_a_sig, is_defined, tof } = jsgui;
81
+
82
+ //var Web_Resource = require('./website-resource');
83
+ const Resource = jsgui.Resource;
84
+ const Router = jsgui.Router;
85
+ //const Evented_Class = jsgui.Evented_Class;
86
+
87
+ const Resource_Pool = require("./server-resource-pool");
88
+ //var Resource_Web_Admin = require('../web-admin');
89
+
90
+ const Site_JavaScript = require("./website-javascript-resource");
91
+ //console.log('1) Site_JavaScript', Site_JavaScript);
92
+ const Site_CSS = require("./website-css-resource");
93
+ const Site_Static_HTML = require("./website-static-html-resource");
94
+ //var DB_Web_Resource = require('../../web/db-resource-postgres');
95
+ //var database_resource_factory = require('../../db/resource/factory');
96
+
97
+ const Resource_Publisher = require("../publishing/resource-publisher");
98
+ const Observable_Publisher = require("../publishing/observable-publisher");
99
+ const Function_Publisher = require("../publishing/function-publisher");
100
+ //const Data_Resource = require("./data-resource");
101
+
102
+ // Proxy_Server_Resource possibly.
103
+ // Note that the client should be able to access a Proxy_Server_Resource if needed.
104
+ // Could just send request onwards and do same for response.
105
+ // Buffering rate-limiting proxies too though?
106
+
107
+
108
+ // May help with FirstPoint_Server.
109
+
110
+ // Could move the publishing parts to Website_Resource_Publisher perhaps.
111
+
112
+
113
+
114
+ // Maybe worth just having a Website object.
115
+ // Then the Website_Resource can encapsulate that.
116
+
117
+ // Better if this wraps the Website object?
118
+
119
+ // A Website has its own Website Resource Pool?
120
+
121
+ // Make Website_Resource into the wrapper that wraps Website?
122
+ // Or we don't need that, just use HTTP_Website_Publisher.
123
+
124
+ // A lot of important functionality here though...
125
+ // Creating the various resources to add to the website resource pool on the server.
126
+
127
+ // But it's going to be the publishers rather than the resources processing HTTP requests.
128
+ // Change of architecture.
129
+
130
+
131
+ // Maybe won't need the variety of resources.
132
+ // May be simpler to program for.
133
+ // Will initially be more compilation & bundling oriented
134
+ // Then will send those pieces of data to the relevant HTTP handlers.
135
+ // Less wrapped in Resource classes and terminology.
136
+ // Will be able to publish functionality as Resource should I want to.
137
+
138
+
139
+
140
+
141
+
142
+
143
+
144
+ class Website_Resource extends Resource {
145
+ constructor(spec = {}) {
146
+
147
+ throw 'Stop - Discontinued - look for alternatives for the moment.';
148
+
149
+ super(spec);
150
+ // A bit of a special resource here because it has its own resource_pool.
151
+ let resource_pool = new Resource_Pool({
152
+ name: "Website Resource Pool"
153
+ });
154
+ this.resource_pool = resource_pool;
155
+ let database_spec = spec.database;
156
+ let web_database_resource;
157
+
158
+ if (database_spec) {
159
+ database_spec.name = database_spec.name || database_spec.database_name;
160
+ let database_resource = database_resource_factory(database_spec);
161
+ database_resource.start();
162
+ // should start automatically when in the pool?
163
+ // does the pool need to be told to start?
164
+ // Though probably don't want to start the resource on initialization.
165
+ resource_pool.add(database_resource);
166
+ web_database_resource = new DB_Web_Resource({
167
+ database: database_resource,
168
+ meta: {
169
+ name: "Web DB",
170
+ pool: resource_pool
171
+ }
172
+ });
173
+ }
174
+
175
+ // Quite a generalised interface it seems.
176
+ if (web_database_resource) {
177
+ resource_pool.add(web_database_resource);
178
+ }
179
+
180
+ var router = new Router({
181
+ name: "Site Router"
182
+ });
183
+
184
+ this.router = router;
185
+
186
+ var spec_web_admin = {
187
+ //'web_database': web_database_resource,
188
+ meta: {
189
+ name: "Web Admin"
190
+ }
191
+
192
+ };
193
+ // Possibly run web admin from within the web resource itself?
194
+ // The web admin could use its own website resource.
195
+
196
+ //if (web_database_resource) {
197
+ // spec_web_admin.web_database = web_database_resource;
198
+ //}
199
+
200
+ var img_resource = new Site_Images({
201
+ //'meta': {
202
+ name: "Site Images",
203
+ pool: resource_pool
204
+ // }
205
+ });
206
+
207
+ // Seems like site JS is / will use a compilation resource.
208
+
209
+ var js_resource = new Site_JavaScript({
210
+ //'meta': {
211
+ name: "Site JavaScript",
212
+ pool: resource_pool
213
+ //}
214
+ });
215
+
216
+ // Also want a static HTML server.
217
+ // Would serve index.html by default I think???
218
+ // Probably with the static or simplest settings.
219
+
220
+ var static_html_resource;
221
+
222
+ if (spec === "static") {
223
+ static_html_resource = new Site_Static_HTML({
224
+ //'meta': {
225
+ name: "Static HTML",
226
+ pool: resource_pool
227
+ //}
228
+ });
229
+ resource_pool.push(static_html_resource);
230
+ // Perhaps set it up with the specific files (automatically)?
231
+ // Probably with the index.html
232
+ }
233
+ var css_resource = new Site_CSS({
234
+ //'meta': {
235
+ name: "Site CSS",
236
+ pool: resource_pool
237
+ //}
238
+ });
239
+
240
+ js_resource.on('extracted-controls-css', str_extracted_css => {
241
+ css_resource.serve_str_css('controls.css', str_extracted_css);
242
+ // Will serve this as controls.css
243
+ // Separate HTTP request, will get more CSS for the moment.
244
+
245
+ });
246
+
247
+
248
+ // And this can make a few other resources, like the compilation resource.
249
+ // Website resource could include compilation resources?
250
+ // But maybe they will be included on the server
251
+ // May need some processor rationing with compilations taking place.
252
+
253
+
254
+ // javascript and css resources.
255
+ resource_pool.push(router);
256
+ resource_pool.push(img_resource);
257
+ resource_pool.push(js_resource);
258
+ resource_pool.push(css_resource);
259
+ //resource_pool.push(data_resource);
260
+
261
+ // anything ending in .css as well.
262
+ // Routing maybe wouldn't work like that.
263
+ //router.set_route('*.css', css_resource, css_resource.process);
264
+
265
+ router.set_route("css/*", css_resource, css_resource.process);
266
+ router.set_route("js/*", js_resource, js_resource.process);
267
+ // As well as this, it could get the JavaScript resource to serve the JavaScript from the app's js directory.
268
+ js_resource.serve_directory("js");
269
+ router.set_route("i/*", img_resource, img_resource.process);
270
+ router.set_route("img/*", img_resource, img_resource.process);
271
+ router.set_route("imgs/*", img_resource, img_resource.process);
272
+ router.set_route("images/*", img_resource, img_resource.process);
273
+ this.map_resource_publishers = this.map_resource_publishers || {};
274
+ router.set_route("resources/:resource_name/*", this, (req, res) => {
275
+ let { url, method } = req;
276
+ let s_url = url.split("/");
277
+ let resource_short_name = s_url[2];
278
+ let resource_publisher = this.map_resource_publishers[resource_short_name];
279
+ if (resource_publisher) {
280
+ resource_publisher.handle_http(req, res);
281
+ }
282
+ });
283
+ if (!is_defined(spec)) spec = {};
284
+ this.resource_pool = resource_pool;
285
+ }
286
+
287
+ publishing_get_pub(item) {
288
+ let pub;
289
+ if (item instanceof jsgui.Resource) {
290
+ pub = new Resource_Publisher({
291
+ resource: item
292
+ });
293
+ } else {
294
+ // if its a function
295
+ // return that function call to the response.
296
+ let t_item = typeof item;
297
+ if (t_item === "function") {
298
+ // Function_Call_Publisher
299
+ // could respec this.
300
+ // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
301
+
302
+ pub = new Function_Publisher({
303
+ fn: item
304
+ });
305
+ //this.map_resource_publishers[published_name] = pub;
306
+ //
307
+ } else {
308
+ if (item.next && item.complete && item.error) {
309
+ // assuming observable
310
+ // Observable publisher
311
+ // One way sending...
312
+ //console.log('using Observable_Publisher');
313
+ pub = new Observable_Publisher({
314
+ obs: item
315
+ });
316
+ // or not a resource publisher, an observable publisher.
317
+ //this.map_resource_publishers = this.map_resource_publishers || {};
318
+ //this.map_resource_publishers[published_name] = obs_pub;
319
+
320
+ //console.log('2) this', this);
321
+ //console.log('this.map_resource_publishers', this.map_resource_publishers);
322
+ //console.trace();
323
+ } else {
324
+ console.log("item", item);
325
+ throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
326
+ }
327
+ }
328
+ //if (item instanceof Evented_Class) {
329
+ }
330
+ return pub;
331
+ }
332
+
333
+ // publish within resources?
334
+ publish(published_name, item, schema) {
335
+ let sig = get_a_sig(arguments),
336
+ a = arguments,
337
+ l = a.length;
338
+ const single = (published_name, item) => {
339
+ if (item instanceof jsgui.Resource) {
340
+ let resource_publisher = new Resource_Publisher({
341
+ resource: item,
342
+ name: published_name
343
+ });
344
+ this.map_resource_publishers[published_name] = resource_publisher;
345
+
346
+ item.name = item.name || published_name;
347
+ // add that resource!
348
+ // (to the pool?)
349
+ //console.log('item', item);
350
+ this.resource_pool.add(item);
351
+
352
+ //console.log('Object.keys(this.map_resource_publishers)', Object.keys(this.map_resource_publishers));
353
+ } else {
354
+ // if its a function
355
+ // return that function call to the response.
356
+ let t_item = typeof item;
357
+ if (t_item === "function") {
358
+ // Function_Call_Publisher
359
+ // could respec this.
360
+
361
+ // And the Function_Publisher operates through the Publisher API. Not sure what that is right now though.
362
+ // directly attaching the resource publishers?
363
+ let pub = new Function_Publisher({
364
+ fn: item,
365
+ schema: schema
366
+ });
367
+ this.map_resource_publishers[published_name] = pub;
368
+ //
369
+
370
+ } else {
371
+ if (item.next && item.complete && item.error) {
372
+ let obs_pub = new Observable_Publisher({
373
+ obs: item,
374
+ schema: schema
375
+ });
376
+ this.map_resource_publishers[published_name] = obs_pub;
377
+ } else {
378
+ console.log("item", item);
379
+ throw "Unrecognised item type. Possibly node module versions are wrong / have not been linked fully.";
380
+ }
381
+ }
382
+ //if (item instanceof Evented_Class) {
383
+ }
384
+ };
385
+
386
+ if (sig === "[o]") {
387
+ each(a[0], (v, i) => {
388
+ single(i, v);
389
+ })
390
+ } else {
391
+
392
+ single(published_name, item);
393
+ }
394
+ }
395
+
396
+ get resource_names() {
397
+ //console.log('this.resource_pool', this.resource_pool);
398
+ return this.resource_pool.resource_names;
399
+ }
400
+
401
+ get_resource(resource_name) {
402
+ var resource_pool = this.resource_pool;
403
+ return resource_pool.get_resource(resource_name);
404
+ }
405
+
406
+ get def_resource_publishers() {
407
+ const res = {};
408
+ each(this.map_resource_publishers, (rp, name) => {
409
+
410
+ let def = {
411
+ name: name,
412
+ type: rp.type
413
+ }
414
+ res[name] = def;
415
+ if (rp.type === 'function') {
416
+ if (rp.schema) def.schema = rp.schema;
417
+ }
418
+ });
419
+ return res;
420
+ }
421
+
422
+ start(callback) {
423
+ var resource_pool = this.resource_pool;
424
+ resource_pool.start(callback);
425
+ }
426
+
427
+ meets_requirements() {
428
+ // Likely will be part of Status
429
+
430
+ //return false;
431
+
432
+ return true;
433
+ }
434
+
435
+ // Needs to be able to process HTTP requests. A bit like the Router in that way.
436
+ process(req, res) {
437
+ //console.log('website process request req.url', req.url);
438
+ //throw 'stop';
439
+
440
+ var remoteAddress = req.connection.remoteAddress;
441
+ var router = this.router;
442
+ var res_process = router.process(req, res);
443
+
444
+ // Likely will need to make this more advanced, possibly to suit a spec.
445
+ // Website_Resource_Publisher may be the best place to deal with this.
446
+
447
+ // Gives it to the router to process.
448
+ // Possibly we need a Control_Publisher?
449
+ // To publish a Control at an address on the web.
450
+
451
+ console.log('Website_Resource !!res_process', !!res_process);
452
+
453
+ // Need more HTTP request to response handlers.
454
+ // Or just HTTP handlers really.
455
+ // They may be best accessed by the router though.
456
+ // Make a decent function abstraction for them next time I need an HTTP handler.
457
+
458
+
459
+
460
+
461
+
462
+
463
+
464
+
465
+
466
+ if (res_process === false) {
467
+ if (req.url === "/") {
468
+ // Seems like too much of a special case.
469
+
470
+ // Send this to the static HTML processing system.
471
+
472
+ /*
473
+
474
+ var static_html_resource = this.resource_pool.get_resource(
475
+ "Static HTML"
476
+ );
477
+ //console.log('static_html_resource', static_html_resource);
478
+ // And lets get the static resource to process it
479
+ if (static_html_resource) {
480
+ static_html_resource.process(req, res);
481
+ }
482
+ */
483
+
484
+ // Show the default page. ???
485
+
486
+ //console.log('deprecated functionality');
487
+ //throw 'stop';
488
+
489
+ res.writeHead(404, {
490
+ "Content-Type": "text/plain"
491
+ });
492
+ res.write("404 Not Found\n");
493
+ res.end();
494
+
495
+ } else {
496
+ // show a 404
497
+ res.writeHead(404, {
498
+ "Content-Type": "text/plain"
499
+ });
500
+ res.write("404 Not Found\n");
501
+ res.end();
502
+ }
503
+ }
504
+ }
505
+ }
506
+
507
+ module.exports = Website_Resource;
@@ -0,0 +1,41 @@
1
+
2
+ // Will make use of features already in jsgui to handle / do compilation.
3
+
4
+
5
+ // Want compilation to be handled lower level within the jsgui system.
6
+ // jsgui.compile(code, compilation_options);
7
+
8
+ // jsgui compiler toolkit could go in lang-tools or even lang-mini.
9
+ // there is also the jsx compiler, should be similar to call to Babel.
10
+
11
+
12
+ // Handling rust => wasm compilation will be nice too.
13
+ // And other languages that compile to WASM, such as C and C++.
14
+
15
+ // Much of it will require HD space.
16
+ // Want to wrap that in a convenient interface that could be upgraded to RAM drive,
17
+ // network RAM drive etc.
18
+
19
+ // May need to install / verify installation of necessary compilers, eg cargo, gcc.
20
+
21
+ // And specific compilation / compiler resources?
22
+ // As resources, the management of their access will be controlled (maybe made available remotely) programatically.
23
+
24
+ // Want babel, esbuild
25
+ // Also rust.
26
+ // Rust to integrated WASM would be very nice.
27
+ // Being able to write rust files that seamlessly connect with JS files.
28
+ // Or even integrating Rust code within a js file....
29
+ // or xjs?
30
+
31
+
32
+
33
+
34
+
35
+
36
+
37
+
38
+
39
+
40
+
41
+
@@ -1,3 +1,11 @@
1
+ // Change name to HTTP_Resource?
2
+
3
+ // May be worth doing more on local / remote transformation resources.
4
+ // Even loading the remote code to run locally where applicable.
5
+
6
+
7
+ // HTTP_Resource seems like a better name as it processes an HTTP request.
8
+
1
9
 
2
10
  var path = require('path'),
3
11
  fs = require('fs'),
@@ -37,6 +45,12 @@ var Collection = jsgui.Collection;
37
45
  // Ideally want it like image keys, then options for max size and also quality.
38
46
  //
39
47
 
48
+ // Data_HTTP_Resource ?
49
+
50
+ // Handled with request+response.
51
+ // What about data that needs to be in page load?
52
+
53
+ // Maybe assume resources always deal with data?
40
54
 
41
55
  class Data_Resource extends Resource {
42
56
 
@@ -10,6 +10,8 @@
10
10
  Resource, JeSuisXML, Cookies, fs2) {
11
11
  */
12
12
 
13
+ // A RAM FS may be of use here too. Cross-platform, simple to use.
14
+
13
15
  var libpath = require('path'),
14
16
  fs = require('fs'),
15
17
  url = require('url'),
@@ -22,7 +24,6 @@ var libpath = require('path'),
22
24
  Cookies = require('cookies'),
23
25
  fs2 = require('../fs2');
24
26
 
25
-
26
27
  /*
27
28
 
28
29
  var stringify = jsgui.stringify,
@@ -50,12 +51,9 @@ const fnlfs = require('fnlfs');
50
51
  // Cloud_FS_Resource
51
52
  // SFTP_FS_Resource
52
53
 
53
-
54
54
  // Publishing an FS resource would enable a directory browsing app.
55
55
  // File_Tree, and connect to the client-side Data_Resource.
56
56
 
57
-
58
-
59
57
  const {
60
58
  is_directory, dir_contents
61
59
  } = fnlfs;
@@ -533,6 +533,9 @@ const deep_iterate_babel_node_$INTERNAL = (babel_node, depth, path, common, call
533
533
  } else if (type === 'Super') {
534
534
  return deep_iterate_babel_super_node(babel_node, depth, path, common, callback);
535
535
  } else {
536
+
537
+ // Need to make this handle a template literal too.
538
+
536
539
  console.log('');
537
540
  console.log('type', type);
538
541
  console.log('');
@@ -9,7 +9,7 @@
9
9
 
10
10
  // Load a JS file into an OO structure
11
11
 
12
- const JS_File = require('..//JS_File/JS_File');
12
+ const JS_File = require('../JS_File/JS_File');
13
13
  //const JS_File_Comprehension = require('../JS_File_Comprehension');
14
14
  const path = require('path');
15
15
  const fs = require('fs');
@@ -33,7 +33,7 @@
33
33
 
34
34
 
35
35
 
36
- const JS_File = require('..//JS_File/JS_File');
36
+ const JS_File = require('../JS_File/JS_File');
37
37
  //const JS_File_Comprehension = require('../JS_File_Comprehension');
38
38
  const path = require('path');
39
39
  const fs = require('fs');
@@ -48,7 +48,7 @@ const test_js_file = () => {
48
48
  // stream the file in.
49
49
  const lm_path = '../../../../../tools/lang-mini/lang-mini.js'
50
50
  const lt_path = '../../../../../tools/lang-tools/lang.js'
51
- const fnl_path = '../../../../../tools/fnl/fnl.js'
51
+ const fnl_path = require.resolve('fnl');
52
52
  const filecomp_path = '../JS_File_Comprehension.js';
53
53
  const jsfile_path = '../JS_File/JS_File.js';
54
54
  const jsbuilder_path = '../JS_Builder.js';
@@ -27,6 +27,7 @@ const test_lang_mini_project = () => {
27
27
  // Worth working with a lower level part of jsgui, such as lang-mini.
28
28
  // lang-mini itself has an external reference.
29
29
  // stream the file in.
30
+ throw 'STOP';
30
31
  const lm_path = '../../../../../tools/lang-mini/lang-mini.js'
31
32
 
32
33
  //const file_path = '../JS_File.js';
@@ -0,0 +1,11 @@
1
+ from jsgui3-html
2
+
3
+ jsgui.Resource = require('./resource/resource');
4
+ jsgui.Resource_Pool = require('./resource/pool');
5
+ jsgui.Resource.Data_KV = require('./resource/data-kv-resource');
6
+ jsgui.Resource.Data_Transform = require('./resource/data-transform-resource');
7
+
8
+
9
+ Want a really simple search & replace type template system for the moment.
10
+
11
+ Integrating react into the server at various levels would help.
@@ -0,0 +1,29 @@
1
+
2
+
3
+ var jsgui = require("jsgui3-html");
4
+ const { each, get_a_sig, is_defined, tof } = jsgui;
5
+
6
+ //var Web_Resource = require('./website-resource');
7
+ const Resource = jsgui.Resource;
8
+ // Proxy_Server_Resource possibly.
9
+ // Note that the client should be able to access a Proxy_Server_Resource if needed.
10
+ // Could just send request onwards and do same for response.
11
+ // Buffering rate-limiting proxies too though?
12
+
13
+
14
+ // May help with FirstPoint_Server.
15
+
16
+ // Could move the publishing parts to Website_Resource_Publisher perhaps.
17
+
18
+
19
+
20
+
21
+
22
+
23
+ class Server_Installed_Tools extends Resource {
24
+ constructor(spec = {}) {
25
+ super(spec);
26
+ }
27
+ }
28
+
29
+ module.exports = Server_Installed_Tools;