jsgui3-server 0.0.75 → 0.0.79

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 (158) hide show
  1. package/examples/client-side-popup-menu-button.html +93 -93
  2. package/examples/controls/_html-server-color-palette.js +114 -114
  3. package/examples/controls/html-server-combo-box.js +104 -104
  4. package/examples/controls/html-server-list.js +98 -98
  5. package/examples/controls/html-server-popup-menu-button.js +114 -114
  6. package/examples/controls/html-server-start-stop-toggle-button.js +146 -146
  7. package/examples/controls/scs-arrow-button.js +36 -36
  8. package/examples/controls/scs-date-picker.js +157 -157
  9. package/examples/controls/scs-file-browser.js +82 -82
  10. package/examples/controls/scs-item.js +159 -159
  11. package/examples/controls/scs-month-arrow-selector.js +126 -126
  12. package/examples/controls/scs-month-view.js +95 -95
  13. package/examples/controls/scs-start-stop-toggle-button.js +40 -40
  14. package/examples/controls/scs-tree.js +49 -49
  15. package/examples/controls/scs-year-arrow-selector.js +127 -127
  16. package/examples/demos/date-picker.js +119 -119
  17. package/examples/demos/explain-encapsulation.js +9 -9
  18. package/examples/demos/resizing.js +35 -35
  19. package/examples/demos/server_time.js +6 -6
  20. package/examples/demos/square_box.js +324 -324
  21. package/examples/html-rendering.js +20 -20
  22. package/examples/html-server.js +102 -100
  23. package/fs2.js +1836 -1836
  24. package/module.js +21 -21
  25. package/old/single-control-server.js +418 -418
  26. package/package.json +44 -42
  27. package/publishing/function-publisher.js +202 -202
  28. package/publishing/notes.md +5 -5
  29. package/publishing/observable-publisher.js +118 -118
  30. package/publishing/resource-publisher.js +306 -306
  31. package/resources/data-resource.js +104 -104
  32. package/resources/fs-resource.js +148 -148
  33. package/resources/jsbuilder/Abstract_Single_Declaration.js +105 -0
  34. package/resources/jsbuilder/Abstract_Single_Declaration_Sequence.js +43 -0
  35. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node.js +62 -0
  36. package/resources/jsbuilder/JS_AST/JS_AST_Abstract_Node_Group.js +42 -0
  37. package/resources/jsbuilder/JS_AST/JS_AST_Group_Shared.js +62 -0
  38. package/resources/jsbuilder/JS_AST/JS_AST_Node.js +94 -0
  39. package/resources/jsbuilder/JS_AST/JS_AST_Node_0-Core.js +228 -0
  40. package/resources/jsbuilder/JS_AST/JS_AST_Node_1-Babel.js +338 -0
  41. package/resources/jsbuilder/JS_AST/JS_AST_Node_10-Changing.js +40 -0
  42. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.1-Child.js +97 -0
  43. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.2-Parent.js +38 -0
  44. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.1.3-Ancestor.js +62 -0
  45. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.2-Inner.js +44 -0
  46. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.3-All.js +73 -0
  47. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.4-Sibling.js +93 -0
  48. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.5-Available_In_Scope.js +29 -0
  49. package/resources/jsbuilder/JS_AST/JS_AST_Node_2.9-Signature.js +116 -0
  50. package/resources/jsbuilder/JS_AST/JS_AST_Node_3-Basics.js +160 -0
  51. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.0-Basics_First.js +179 -0
  52. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.1-Basics_Second.js +88 -0
  53. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.0.99-Basics_Last.js +92 -0
  54. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1-Basics_Each.js +137 -0
  55. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.1.5-Basics_Count.js +74 -0
  56. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.2-Basics_Filter.js +40 -0
  57. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.3-Basics_Collect.js +86 -0
  58. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.4-Basics_Select.js +43 -0
  59. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.5-Basics_Find.js +41 -0
  60. package/resources/jsbuilder/JS_AST/JS_AST_Node_3.6-Basics_Callmap.js +55 -0
  61. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.0-Index_Indexes.js +46 -0
  62. package/resources/jsbuilder/JS_AST/JS_AST_Node_4.1-Index.js +344 -0
  63. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.0-Category.js +39 -0
  64. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.1-Category_Identifier.js +31 -0
  65. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.2-Category_Literal.js +29 -0
  66. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.3-Category_Expression.js +27 -0
  67. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.4-Category_Pattern.js +9 -0
  68. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.5-Category_Declaration.js +44 -0
  69. package/resources/jsbuilder/JS_AST/JS_AST_Node_5.6-Category_Statement.js +22 -0
  70. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.0-Type.js +87 -0
  71. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.1-Type_Class_Declaration.js +9 -0
  72. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.2-Type_Variable_Declaration.js +28 -0
  73. package/resources/jsbuilder/JS_AST/JS_AST_Node_6.3-Type_Variable_Declarator.js +29 -0
  74. package/resources/jsbuilder/JS_AST/JS_AST_Node_7-Query.js +737 -0
  75. package/resources/jsbuilder/JS_AST/JS_AST_Node_8-Features.js +65 -0
  76. package/resources/jsbuilder/JS_AST/JS_AST_Node_9-Planning.js +32 -0
  77. package/resources/jsbuilder/JS_AST/JS_AST_Node_Arrangement.js +15 -0
  78. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Declared_Object.js +306 -0
  79. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature.js +78 -0
  80. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declaration.js +249 -0
  81. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Node_Feature_Declarator.js +139 -0
  82. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature.js +10 -0
  83. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exported.js +101 -0
  84. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Feature_Exports.js +61 -0
  85. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/JS_AST_Root_Node_Interpreted.js +180 -0
  86. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/_JSGUI_Root_Node_Interpreted.js +43 -0
  87. package/resources/jsbuilder/JS_AST/JS_AST_Node_Feature/JS_AST_Root_Node_Feature/special_case_objectassign_to_object.js +12 -0
  88. package/resources/jsbuilder/JS_AST/JS_AST_Node_Group.js +35 -0
  89. package/resources/jsbuilder/JS_AST/JS_AST_Operation.js +11 -0
  90. package/resources/jsbuilder/JS_AST/JS_AST_Operation_On_Relationship.js +32 -0
  91. package/resources/jsbuilder/JS_AST/JS_AST_Ordered_Relationship_Node_To_Group.js +38 -0
  92. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal.js +40 -0
  93. package/resources/jsbuilder/JS_AST/JS_AST_Ordinal_Relationship.js +25 -0
  94. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_To_Group.js +201 -0
  95. package/resources/jsbuilder/JS_AST/JS_AST_Relationship_Node_Within_Group_To_Node.js +44 -0
  96. package/resources/jsbuilder/JS_AST/_JS_AST_Node_3.8-Query_Features.js +77 -0
  97. package/resources/jsbuilder/JS_AST/query/all.js +0 -0
  98. package/resources/jsbuilder/JS_AST/query/enable_array_as_queryable.js +228 -0
  99. package/resources/jsbuilder/JS_AST/query/find_object_keys.js +405 -0
  100. package/resources/jsbuilder/JS_AST/query/node_queries.js +9 -0
  101. package/resources/jsbuilder/JS_AST/query/root_queries.js +0 -0
  102. package/resources/jsbuilder/JS_AST/query/root_query_identidy.js +12 -0
  103. package/resources/jsbuilder/JS_AST_Node_Extended/JSGUI_Singular_Declaration.js +86 -0
  104. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Declaration.js +124 -0
  105. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended.js +88 -0
  106. package/resources/jsbuilder/JS_AST_Node_Extended/JS_AST_Node_Extended_0-Core.js +11 -0
  107. package/resources/jsbuilder/JS_Builder.js +10 -36
  108. package/resources/jsbuilder/JS_File/Feature/JS_File_Declared_Object.js +32 -0
  109. package/resources/jsbuilder/JS_File/Feature/JS_File_Exported_Object_Info.js +26 -0
  110. package/resources/jsbuilder/JS_File/Feature/JS_File_Exports.js +79 -0
  111. package/resources/jsbuilder/JS_File/Feature/JS_File_Feature.js +18 -0
  112. package/resources/jsbuilder/JS_File/Feature/JS_File_Imported_Object_Info.js +26 -0
  113. package/resources/jsbuilder/JS_File/Feature/JS_File_Imports.js +9 -0
  114. package/resources/jsbuilder/JS_File/JS_File.js +12 -0
  115. package/resources/jsbuilder/JS_File/JS_File_0-Core.js +202 -0
  116. package/resources/jsbuilder/JS_File/JS_File_1-Early_Parse.js +175 -0
  117. package/resources/jsbuilder/JS_File/JS_File_2-Babel.js +81 -0
  118. package/resources/jsbuilder/JS_File/JS_File_3-JS_AST_Node.js +86 -0
  119. package/resources/jsbuilder/JS_File/JS_File_4-Query.js +414 -0
  120. package/resources/jsbuilder/JS_File/JS_File_4.1-Query_Features.js +415 -0
  121. package/resources/jsbuilder/JS_File/JS_File_5-Planning.js +59 -0
  122. package/resources/jsbuilder/JS_File/JS_File_6-Changing.js +24 -0
  123. package/resources/jsbuilder/JS_File/JS_File_Export_Reference.js +12 -0
  124. package/resources/jsbuilder/JS_File/JS_File_Import_Reference.js +24 -0
  125. package/resources/jsbuilder/JS_File/JS_File_Import_References.js +32 -0
  126. package/resources/jsbuilder/JS_File/JS_File_Processor.js +16 -0
  127. package/resources/jsbuilder/JS_File/JS_Files.js +16 -0
  128. package/resources/jsbuilder/Module.js +14 -0
  129. package/resources/jsbuilder/Platform.js +13 -53
  130. package/resources/jsbuilder/Platforms.js +69 -15
  131. package/resources/jsbuilder/Project.js +109 -0
  132. package/resources/jsbuilder/Reference.js +1 -1
  133. package/resources/jsbuilder/Reference_Sequence.js +16 -7
  134. package/resources/jsbuilder/Scope.js +30 -0
  135. package/resources/jsbuilder/Variable_Name_Provider.js +43 -0
  136. package/resources/jsbuilder/_JS_File.js +226 -0
  137. package/resources/jsbuilder/ast_query.js +21 -0
  138. package/resources/jsbuilder/babel/babel_consts.js +150 -0
  139. package/resources/jsbuilder/babel/babel_node_tools.js +542 -0
  140. package/resources/jsbuilder/babel/deep_iterate/deep_iterate_babel.js +604 -0
  141. package/resources/jsbuilder/build.js +16 -0
  142. package/resources/jsbuilder/platform_notes.md +66 -0
  143. package/resources/jsbuilder/test/test_ast_node.js +451 -0
  144. package/resources/jsbuilder/test/test_js_file.js +303 -11
  145. package/resources/jsbuilder/test/test_project.js +157 -0
  146. package/resources/local-server-info-resource.js +78 -78
  147. package/resources/process-js.js +537 -537
  148. package/resources/server-resource-pool.js +84 -84
  149. package/resources/website-css-resource.js +411 -411
  150. package/resources/website-javascript-resource.js +761 -751
  151. package/resources/website-resource.js +390 -390
  152. package/resources/website-static-html-resource.js +196 -196
  153. package/server.js +170 -170
  154. package/single-control-server.js +398 -398
  155. package/single-page-app.js +129 -129
  156. package/resources/jsbuilder/Declaration.js +0 -15
  157. package/resources/jsbuilder/Declaration_Sequence.js +0 -15
  158. package/resources/jsbuilder/JS_File.js +0 -77
@@ -1,412 +1,412 @@
1
- /*
2
- if (typeof define !== 'function') {
3
- var define = require('amdefine')(module);
4
- }
5
-
6
- define(['module', 'path', 'fs', 'url', '../../web/jsgui-html', 'os', 'http', 'url', './resource',
7
- '../../web/jsgui-je-suis-xml', 'cookies', '../../fs/jsgui-node-fs2-core'],
8
-
9
- function(module, path, fs, url, jsgui, os, http, libUrl,
10
- Resource, JeSuisXML, Cookies, fs2) {
11
- */
12
-
13
-
14
- // All the CSS that has been put together from the controls...
15
-
16
- // .compile_controls_css(controls)
17
-
18
-
19
- var path = require('path'),
20
- fs = require('fs'),
21
- url = require('url'),
22
- jsgui = require('jsgui3-html'),
23
- os = require('os'),
24
- http = require('http'),
25
- libUrl = require('url'),
26
- Resource = jsgui.Resource,
27
- Cookies = require('cookies'),
28
- fs2 = require('../fs2');
29
-
30
- const fnl = require('fnl');
31
-
32
- var stringify = jsgui.stringify,
33
- each = jsgui.each,
34
- arrayify = jsgui.arrayify,
35
- tof = jsgui.tof;
36
- var filter_map_by_regex = jsgui.filter_map_by_regex;
37
- var Class = jsgui.Class,
38
- Data_Object = jsgui.Data_Object;
39
- //Enhanced_Data_Object = jsgui.Enhanced_Data_Object;
40
- var fp = jsgui.fp,
41
- is_defined = jsgui.is_defined;
42
- var Collection = jsgui.Collection;
43
-
44
- const prom_or_cb = fnl.prom_or_cb;
45
-
46
- // Extends AutoStart_Resource?
47
-
48
- // May need to change around a fair few references to make it workable.
49
- // May need some more complicated logic to change it to the path for service.
50
-
51
- // jsgui3 now has its own css in the 'client' folder.
52
- // Should be able to just serve css files from there.
53
-
54
-
55
- // and a map of all css text?
56
-
57
- const compile_controls_css = controls => {
58
- // go through all the controls, look for the .css property (on the class)
59
-
60
- //let res = '';
61
- const arr_css = [];
62
-
63
-
64
- each(controls, Ctrl => {
65
-
66
- const {css} = Ctrl;
67
- if (css) arr_css.push(css);
68
-
69
-
70
- });
71
- const str_css = arr_css.join('\n');
72
- return str_css;
73
-
74
- }
75
-
76
-
77
-
78
- var serve_css_string = function(css, response) {
79
- response.writeHead(200, {
80
- 'Content-Type': 'text/css'
81
- });
82
- response.end(css);
83
- }
84
-
85
- // Could compile sass or whatever.
86
- // Could gzip compress.
87
-
88
- var serve_css_file_from_disk = function (filePath, response) {
89
- // look for the file in two places.
90
- // look within the project
91
- // look within jsgui
92
-
93
- // Checking if a file exists is not recommended.
94
- // Possible race condition where exists checks and sees it's there, something else deletes it, then try to open the file thinking that it exists.
95
- // Now recommended to open the file and handle error if it does not exist.
96
- //
97
-
98
- var file_path_in_project = filePath;
99
- // And also need to work outs path within the ws system.
100
-
101
- let attempt_load = (path, callback) => {
102
- fs2.load_file_as_string(path, function (err, data) {
103
- if (err) {
104
- console.log('could not open file path', path);
105
- //jsgui_css_file_path = '../../' + filePath;
106
- //console.log('jsgui_css_file_path', jsgui_css_file_path);
107
- callback(null, false);
108
- } else {
109
- callback(null, data);
110
- }
111
- });
112
- }
113
-
114
- // should get and use the current module path.
115
-
116
- // console.log(__dirname);
117
-
118
- let internal_client_path = path.resolve(__dirname, '../client');
119
-
120
- //
121
-
122
-
123
- // just the file name
124
-
125
- let filename = path.basename(filePath);
126
-
127
-
128
- //console.log('filePath', filePath);
129
-
130
-
131
-
132
- let internal_client_file_path = path.join(internal_client_path, filePath);
133
- let internal_client_filename = path.join(internal_client_path, filename);
134
-
135
- //console.log('internal_client_file_path', internal_client_file_path);
136
- //console.log('internal_client_filename', internal_client_filename);
137
-
138
- // chould be able to use the path of this module itself for basic / default css.
139
- // Always want jsgui to be able to return its own css.
140
- // This worked while serving examples from within jsgui.
141
- // Now we need the css to be contained within jsgui itself.
142
- // just the file name, check if that css file is in the client path.
143
- // '/css/basic.css' it treats the client path as /css but only will serve css from that path.
144
-
145
- let candidate_paths = [filePath, internal_client_file_path, './client/app.css', '../../css/' + filePath, './css/' + filePath, './' + filePath, '../../ws/' + filePath, '../../../' + filePath];
146
- let c = 0,
147
- l = candidate_paths.length,
148
- spath;
149
- let go = () => {
150
- if (c < l) {
151
- spath = candidate_paths[c];
152
- //console.log('spath', spath);
153
- let rpath = path.resolve(spath);
154
-
155
- //console.log('rpath', rpath);
156
-
157
- //console.log('path css test', (rpath.lastIndexOf('.css') === rpath.length - 4));
158
- // Security check
159
- if (rpath.toLowerCase().lastIndexOf('.css') === rpath.length - 4) {
160
- attempt_load(spath, (err, res_load) => {
161
- if (res_load === false) {
162
- c++;
163
- go();
164
- } else {
165
- next(null, res_load);
166
- }
167
- });
168
- } else {
169
- next(null, false);
170
- }
171
-
172
- //console.log('rpath', rpath);
173
-
174
- //c++;
175
- //go();
176
- } else {
177
- next(null, false);
178
- }
179
- }
180
- go();
181
- let next = (err, css) => {
182
- //console.log('css', css);
183
- if (css !== false) {
184
- //console.log('css', css);
185
- response.writeHead(200, {
186
- 'Content-Type': 'text/css'
187
- });
188
- response.end(css);
189
- } else {
190
- console.log('could not load css', filePath);
191
- // serve a 404?
192
- response.writeHead(404, {
193
- "Content-Type": "text/plain"
194
- });
195
- response.write("404 Not Found\n");
196
- response.end();
197
- }
198
- }
199
- }
200
-
201
- // compile_controls_css
202
- // Serving loaded / generated / compiled css from a buffer looks like it makes the most sense.
203
- // Still more to do to get the whole framework working well / efficiently as a whole.
204
- // Should make for a very efficient programming style once this is done.
205
-
206
-
207
-
208
-
209
-
210
-
211
-
212
-
213
- class Site_CSS extends Resource {
214
- constructor(spec) {
215
- super(spec);
216
- //this.meta.set('custom_paths', new Data_Object({}));
217
- this.custom_paths = new Data_Object({});
218
- // Custom paths buffer?
219
-
220
- //this.map_css_uncompressed_buffers = {};
221
-
222
- this.map_buffers = {};
223
-
224
- // May be metter to make a map - buffer of the css that gets served.
225
- // Including gzip too where appropriate.
226
-
227
- // Those are custom file paths.
228
- // could have a collection of directories, indexed by name, that get served.
229
- // Index the collection by string value?
230
- //this.meta.set('served_directories', new Collection({'index_by': 'name'}));
231
- this.served_directories = new Collection({
232
- 'index_by': 'name'
233
- });
234
- }
235
- 'start' (callback) {
236
- callback(null, true);
237
- }
238
- 'serve_directory' (path) {
239
- // Serves that directory, as any files given in that directory can be served from /js
240
- var served_directories = this.served_directories;
241
- //console.log('served_directories ' + stringify(served_directories));
242
- //served_directories.push(path);
243
- // May also want to serve a directory under a different path.
244
- served_directories.push({
245
- 'name': path
246
- });
247
- //console.log('served_directories ' + stringify(served_directories));
248
- //console.log('path ' + path);
249
- //throw 'stop';
250
- }
251
- 'serve_str_css' (path, str_css) {
252
-
253
- // load it into the uncompressed / raw part of the buffer.
254
- this.map_buffers[path] = {
255
- raw: Buffer.from(str_css)
256
- }
257
-
258
- // Then will check for this when serving in the future.
259
- // When doing process request.
260
-
261
-
262
- }
263
-
264
- // serve_str_css (path to serve it as, str_css)
265
- // will record it into the map_buffers of what to serve under what name
266
-
267
- // Serving compiled css for the jsgui controls will be very useful.
268
- // Then may do some more work on functional control creation.
269
-
270
- // A control factory?
271
- // And can give it the (xml) text spec too?
272
-
273
-
274
-
275
-
276
-
277
- // Serve css as string.
278
- // Want a buffer of csss to serve user specific names.
279
- // Like image resource icons.
280
-
281
-
282
-
283
-
284
-
285
- 'serve' (serve_as, system_file_path, callback) {
286
- return prom_or_cb((resolve, reject) => {
287
- console.log('css serve_as', serve_as);
288
- //this.custom_paths.set(serve_as, system_file_path);
289
- this.custom_paths[serve_as] = system_file_path;
290
- resolve(true);
291
- }, callback);
292
- }
293
- 'process' (req, res) {
294
-
295
- const {map_buffers, pool, custom_paths} = this;
296
-
297
- //console.log('Site_CSS processing HTTP request');
298
- var remoteAddress = req.connection.remoteAddress;
299
- //var custom_paths = this.custom_paths;
300
- var rurl = req.url;
301
- //var pool = this.pool;
302
- // should have a bunch of resources from the pool.
303
- //var pool_resources = pool.resources();
304
- //console.log('pool_resources ' + stringify(pool_resources));
305
- //console.log('css 1) rurl', rurl);
306
- // Need to serve CSS from memory as well.
307
- // Css is in the HTML module. Server needs to send that correct html to the client.
308
- //console.log('custom_paths', custom_paths);
309
- var url_parts = url.parse(req.url, true);
310
- //console.log('url_parts ' + stringify(url_parts));
311
- var splitPath = url_parts.path.substr(1).split('/');
312
- console.log('resource site css splitPath ', (splitPath));
313
- var custom_response_entry;
314
- // They usually would start /css/ I assume. Not sure when they won't.
315
-
316
- if (splitPath.length === 2) {
317
- if (splitPath[0] === 'css') {
318
-
319
- // Check to see if it's in the prepared css buffers. easy to serve if that's the case.
320
- // check for splitPath[1] existing in map_buffers.
321
-
322
-
323
- if (map_buffers[splitPath[1]]) {
324
- const o_buf_css = map_buffers[splitPath[1]];
325
- const {raw} = o_buf_css;
326
- // the raw buffer.
327
-
328
- // Should be easy enough to serve this raw buffer as CSS.
329
-
330
- serve_css_string(raw, res);
331
- return true;
332
-
333
-
334
- }
335
-
336
-
337
-
338
-
339
-
340
-
341
-
342
- let filename = path.basename(splitPath[1]).slice(0, -4);
343
- //console.log('filename', filename);
344
- //console.log('jsgui.css', jsgui.css);
345
- //console.log('!!jsgui.css[filename]', !!jsgui.css[filename]);
346
-
347
- // will set jsgui.css
348
- // maybe the property should not be there though.
349
- // definitely seems like the wrong way to buffer them.
350
-
351
-
352
-
353
-
354
-
355
- if (jsgui.css[filename]) {
356
- serve_css_string(jsgui.css[filename], res);
357
- return true;
358
- } else {
359
- custom_response_entry = custom_paths[splitPath[1]];
360
- }
361
- }
362
- }
363
-
364
- //if (rurl.substr(0, 1) == '/') rurl = rurl.substr(1);
365
- //rurl = rurl.replace(/\./g, '☺');
366
- //console.log('2) rurl ' + rurl);
367
- //console.log('custom_response_entry ' + (custom_response_entry));
368
-
369
- if (custom_response_entry) {
370
- var tcr = tof(custom_response_entry);
371
- //console.log('tcr ' + tcr);
372
- //throw 'stop';
373
- if (tcr === 'data_value') {
374
- var val = custom_response_entry.value();
375
- //console.log('val ' + val);
376
- throw 'stop';
377
- var tval = tof(val);
378
- if (tval == 'string') {
379
- // then it should be a local file path, serve it.
380
- serve_css_file_from_disk(val, res);
381
- }
382
- }
383
- if (tcr === 'string') {
384
- serve_css_file_from_disk(custom_response_entry, res);
385
- }
386
- } else {
387
- if (splitPath.length > 0) {
388
- if (splitPath[0] === 'css') {
389
- if (splitPath.length > 1) {
390
- if (splitPath.length === 2) {
391
- var fileName = splitPath[1];
392
- //var filePath = 'css/' + fileName;
393
- serve_css_file_from_disk(fileName, res);
394
- } else {
395
- if (splitPath.length === 3) {
396
-
397
- }
398
- }
399
- }
400
- }
401
- }
402
- }
403
- }
404
- }
405
- // Use it separately for the moment.
406
- Site_CSS.compile_controls_css = compile_controls_css;
407
-
408
- //return Site_CSS;
409
-
410
-
411
- //});
1
+ /*
2
+ if (typeof define !== 'function') {
3
+ var define = require('amdefine')(module);
4
+ }
5
+
6
+ define(['module', 'path', 'fs', 'url', '../../web/jsgui-html', 'os', 'http', 'url', './resource',
7
+ '../../web/jsgui-je-suis-xml', 'cookies', '../../fs/jsgui-node-fs2-core'],
8
+
9
+ function(module, path, fs, url, jsgui, os, http, libUrl,
10
+ Resource, JeSuisXML, Cookies, fs2) {
11
+ */
12
+
13
+
14
+ // All the CSS that has been put together from the controls...
15
+
16
+ // .compile_controls_css(controls)
17
+
18
+
19
+ var path = require('path'),
20
+ fs = require('fs'),
21
+ url = require('url'),
22
+ jsgui = require('jsgui3-html'),
23
+ os = require('os'),
24
+ http = require('http'),
25
+ libUrl = require('url'),
26
+ Resource = jsgui.Resource,
27
+ Cookies = require('cookies'),
28
+ fs2 = require('../fs2');
29
+
30
+ const fnl = require('fnl');
31
+
32
+ var stringify = jsgui.stringify,
33
+ each = jsgui.each,
34
+ arrayify = jsgui.arrayify,
35
+ tof = jsgui.tof;
36
+ var filter_map_by_regex = jsgui.filter_map_by_regex;
37
+ var Class = jsgui.Class,
38
+ Data_Object = jsgui.Data_Object;
39
+ //Enhanced_Data_Object = jsgui.Enhanced_Data_Object;
40
+ var fp = jsgui.fp,
41
+ is_defined = jsgui.is_defined;
42
+ var Collection = jsgui.Collection;
43
+
44
+ const prom_or_cb = fnl.prom_or_cb;
45
+
46
+ // Extends AutoStart_Resource?
47
+
48
+ // May need to change around a fair few references to make it workable.
49
+ // May need some more complicated logic to change it to the path for service.
50
+
51
+ // jsgui3 now has its own css in the 'client' folder.
52
+ // Should be able to just serve css files from there.
53
+
54
+
55
+ // and a map of all css text?
56
+
57
+ const compile_controls_css = controls => {
58
+ // go through all the controls, look for the .css property (on the class)
59
+
60
+ //let res = '';
61
+ const arr_css = [];
62
+
63
+
64
+ each(controls, Ctrl => {
65
+
66
+ const {css} = Ctrl;
67
+ if (css) arr_css.push(css);
68
+
69
+
70
+ });
71
+ const str_css = arr_css.join('\n');
72
+ return str_css;
73
+
74
+ }
75
+
76
+
77
+
78
+ var serve_css_string = function(css, response) {
79
+ response.writeHead(200, {
80
+ 'Content-Type': 'text/css'
81
+ });
82
+ response.end(css);
83
+ }
84
+
85
+ // Could compile sass or whatever.
86
+ // Could gzip compress.
87
+
88
+ var serve_css_file_from_disk = function (filePath, response) {
89
+ // look for the file in two places.
90
+ // look within the project
91
+ // look within jsgui
92
+
93
+ // Checking if a file exists is not recommended.
94
+ // Possible race condition where exists checks and sees it's there, something else deletes it, then try to open the file thinking that it exists.
95
+ // Now recommended to open the file and handle error if it does not exist.
96
+ //
97
+
98
+ var file_path_in_project = filePath;
99
+ // And also need to work outs path within the ws system.
100
+
101
+ let attempt_load = (path, callback) => {
102
+ fs2.load_file_as_string(path, function (err, data) {
103
+ if (err) {
104
+ console.log('could not open file path', path);
105
+ //jsgui_css_file_path = '../../' + filePath;
106
+ //console.log('jsgui_css_file_path', jsgui_css_file_path);
107
+ callback(null, false);
108
+ } else {
109
+ callback(null, data);
110
+ }
111
+ });
112
+ }
113
+
114
+ // should get and use the current module path.
115
+
116
+ // console.log(__dirname);
117
+
118
+ let internal_client_path = path.resolve(__dirname, '../client');
119
+
120
+ //
121
+
122
+
123
+ // just the file name
124
+
125
+ let filename = path.basename(filePath);
126
+
127
+
128
+ //console.log('filePath', filePath);
129
+
130
+
131
+
132
+ let internal_client_file_path = path.join(internal_client_path, filePath);
133
+ let internal_client_filename = path.join(internal_client_path, filename);
134
+
135
+ //console.log('internal_client_file_path', internal_client_file_path);
136
+ //console.log('internal_client_filename', internal_client_filename);
137
+
138
+ // chould be able to use the path of this module itself for basic / default css.
139
+ // Always want jsgui to be able to return its own css.
140
+ // This worked while serving examples from within jsgui.
141
+ // Now we need the css to be contained within jsgui itself.
142
+ // just the file name, check if that css file is in the client path.
143
+ // '/css/basic.css' it treats the client path as /css but only will serve css from that path.
144
+
145
+ let candidate_paths = [filePath, internal_client_file_path, './client/app.css', '../../css/' + filePath, './css/' + filePath, './' + filePath, '../../ws/' + filePath, '../../../' + filePath];
146
+ let c = 0,
147
+ l = candidate_paths.length,
148
+ spath;
149
+ let go = () => {
150
+ if (c < l) {
151
+ spath = candidate_paths[c];
152
+ //console.log('spath', spath);
153
+ let rpath = path.resolve(spath);
154
+
155
+ //console.log('rpath', rpath);
156
+
157
+ //console.log('path css test', (rpath.lastIndexOf('.css') === rpath.length - 4));
158
+ // Security check
159
+ if (rpath.toLowerCase().lastIndexOf('.css') === rpath.length - 4) {
160
+ attempt_load(spath, (err, res_load) => {
161
+ if (res_load === false) {
162
+ c++;
163
+ go();
164
+ } else {
165
+ next(null, res_load);
166
+ }
167
+ });
168
+ } else {
169
+ next(null, false);
170
+ }
171
+
172
+ //console.log('rpath', rpath);
173
+
174
+ //c++;
175
+ //go();
176
+ } else {
177
+ next(null, false);
178
+ }
179
+ }
180
+ go();
181
+ let next = (err, css) => {
182
+ //console.log('css', css);
183
+ if (css !== false) {
184
+ //console.log('css', css);
185
+ response.writeHead(200, {
186
+ 'Content-Type': 'text/css'
187
+ });
188
+ response.end(css);
189
+ } else {
190
+ console.log('could not load css', filePath);
191
+ // serve a 404?
192
+ response.writeHead(404, {
193
+ "Content-Type": "text/plain"
194
+ });
195
+ response.write("404 Not Found\n");
196
+ response.end();
197
+ }
198
+ }
199
+ }
200
+
201
+ // compile_controls_css
202
+ // Serving loaded / generated / compiled css from a buffer looks like it makes the most sense.
203
+ // Still more to do to get the whole framework working well / efficiently as a whole.
204
+ // Should make for a very efficient programming style once this is done.
205
+
206
+
207
+
208
+
209
+
210
+
211
+
212
+
213
+ class Site_CSS extends Resource {
214
+ constructor(spec) {
215
+ super(spec);
216
+ //this.meta.set('custom_paths', new Data_Object({}));
217
+ this.custom_paths = new Data_Object({});
218
+ // Custom paths buffer?
219
+
220
+ //this.map_css_uncompressed_buffers = {};
221
+
222
+ this.map_buffers = {};
223
+
224
+ // May be metter to make a map - buffer of the css that gets served.
225
+ // Including gzip too where appropriate.
226
+
227
+ // Those are custom file paths.
228
+ // could have a collection of directories, indexed by name, that get served.
229
+ // Index the collection by string value?
230
+ //this.meta.set('served_directories', new Collection({'index_by': 'name'}));
231
+ this.served_directories = new Collection({
232
+ 'index_by': 'name'
233
+ });
234
+ }
235
+ 'start' (callback) {
236
+ callback(null, true);
237
+ }
238
+ 'serve_directory' (path) {
239
+ // Serves that directory, as any files given in that directory can be served from /js
240
+ var served_directories = this.served_directories;
241
+ //console.log('served_directories ' + stringify(served_directories));
242
+ //served_directories.push(path);
243
+ // May also want to serve a directory under a different path.
244
+ served_directories.push({
245
+ 'name': path
246
+ });
247
+ //console.log('served_directories ' + stringify(served_directories));
248
+ //console.log('path ' + path);
249
+ //throw 'stop';
250
+ }
251
+ 'serve_str_css' (path, str_css) {
252
+
253
+ // load it into the uncompressed / raw part of the buffer.
254
+ this.map_buffers[path] = {
255
+ raw: Buffer.from(str_css)
256
+ }
257
+
258
+ // Then will check for this when serving in the future.
259
+ // When doing process request.
260
+
261
+
262
+ }
263
+
264
+ // serve_str_css (path to serve it as, str_css)
265
+ // will record it into the map_buffers of what to serve under what name
266
+
267
+ // Serving compiled css for the jsgui controls will be very useful.
268
+ // Then may do some more work on functional control creation.
269
+
270
+ // A control factory?
271
+ // And can give it the (xml) text spec too?
272
+
273
+
274
+
275
+
276
+
277
+ // Serve css as string.
278
+ // Want a buffer of csss to serve user specific names.
279
+ // Like image resource icons.
280
+
281
+
282
+
283
+
284
+
285
+ 'serve' (serve_as, system_file_path, callback) {
286
+ return prom_or_cb((resolve, reject) => {
287
+ console.log('css serve_as', serve_as);
288
+ //this.custom_paths.set(serve_as, system_file_path);
289
+ this.custom_paths[serve_as] = system_file_path;
290
+ resolve(true);
291
+ }, callback);
292
+ }
293
+ 'process' (req, res) {
294
+
295
+ const {map_buffers, pool, custom_paths} = this;
296
+
297
+ //console.log('Site_CSS processing HTTP request');
298
+ var remoteAddress = req.connection.remoteAddress;
299
+ //var custom_paths = this.custom_paths;
300
+ var rurl = req.url;
301
+ //var pool = this.pool;
302
+ // should have a bunch of resources from the pool.
303
+ //var pool_resources = pool.resources();
304
+ //console.log('pool_resources ' + stringify(pool_resources));
305
+ //console.log('css 1) rurl', rurl);
306
+ // Need to serve CSS from memory as well.
307
+ // Css is in the HTML module. Server needs to send that correct html to the client.
308
+ //console.log('custom_paths', custom_paths);
309
+ var url_parts = url.parse(req.url, true);
310
+ //console.log('url_parts ' + stringify(url_parts));
311
+ var splitPath = url_parts.path.substr(1).split('/');
312
+ console.log('resource site css splitPath ', (splitPath));
313
+ var custom_response_entry;
314
+ // They usually would start /css/ I assume. Not sure when they won't.
315
+
316
+ if (splitPath.length === 2) {
317
+ if (splitPath[0] === 'css') {
318
+
319
+ // Check to see if it's in the prepared css buffers. easy to serve if that's the case.
320
+ // check for splitPath[1] existing in map_buffers.
321
+
322
+
323
+ if (map_buffers[splitPath[1]]) {
324
+ const o_buf_css = map_buffers[splitPath[1]];
325
+ const {raw} = o_buf_css;
326
+ // the raw buffer.
327
+
328
+ // Should be easy enough to serve this raw buffer as CSS.
329
+
330
+ serve_css_string(raw, res);
331
+ return true;
332
+
333
+
334
+ }
335
+
336
+
337
+
338
+
339
+
340
+
341
+
342
+ let filename = path.basename(splitPath[1]).slice(0, -4);
343
+ //console.log('filename', filename);
344
+ //console.log('jsgui.css', jsgui.css);
345
+ //console.log('!!jsgui.css[filename]', !!jsgui.css[filename]);
346
+
347
+ // will set jsgui.css
348
+ // maybe the property should not be there though.
349
+ // definitely seems like the wrong way to buffer them.
350
+
351
+
352
+
353
+
354
+
355
+ if (jsgui.css[filename]) {
356
+ serve_css_string(jsgui.css[filename], res);
357
+ return true;
358
+ } else {
359
+ custom_response_entry = custom_paths[splitPath[1]];
360
+ }
361
+ }
362
+ }
363
+
364
+ //if (rurl.substr(0, 1) == '/') rurl = rurl.substr(1);
365
+ //rurl = rurl.replace(/\./g, '☺');
366
+ //console.log('2) rurl ' + rurl);
367
+ //console.log('custom_response_entry ' + (custom_response_entry));
368
+
369
+ if (custom_response_entry) {
370
+ var tcr = tof(custom_response_entry);
371
+ //console.log('tcr ' + tcr);
372
+ //throw 'stop';
373
+ if (tcr === 'data_value') {
374
+ var val = custom_response_entry.value();
375
+ //console.log('val ' + val);
376
+ throw 'stop';
377
+ var tval = tof(val);
378
+ if (tval == 'string') {
379
+ // then it should be a local file path, serve it.
380
+ serve_css_file_from_disk(val, res);
381
+ }
382
+ }
383
+ if (tcr === 'string') {
384
+ serve_css_file_from_disk(custom_response_entry, res);
385
+ }
386
+ } else {
387
+ if (splitPath.length > 0) {
388
+ if (splitPath[0] === 'css') {
389
+ if (splitPath.length > 1) {
390
+ if (splitPath.length === 2) {
391
+ var fileName = splitPath[1];
392
+ //var filePath = 'css/' + fileName;
393
+ serve_css_file_from_disk(fileName, res);
394
+ } else {
395
+ if (splitPath.length === 3) {
396
+
397
+ }
398
+ }
399
+ }
400
+ }
401
+ }
402
+ }
403
+ }
404
+ }
405
+ // Use it separately for the moment.
406
+ Site_CSS.compile_controls_css = compile_controls_css;
407
+
408
+ //return Site_CSS;
409
+
410
+
411
+ //});
412
412
  module.exports = Site_CSS;