miqro 6.2.13 → 7.0.1

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 (217) hide show
  1. package/README.md +9 -17
  2. package/build/editor.bundle.js +11601 -10129
  3. package/build/esm/src/bin/types.js +10 -5
  4. package/build/esm/src/cluster.js +1 -1
  5. package/build/esm/src/common/arguments.d.ts +2 -1
  6. package/build/esm/src/common/arguments.js +42 -18
  7. package/build/esm/src/common/assets.d.ts +1 -1
  8. package/build/esm/src/common/assets.js +34 -13
  9. package/build/esm/src/common/esbuild.d.ts +4 -1
  10. package/build/esm/src/common/esbuild.js +31 -26
  11. package/build/esm/src/common/exit.js +4 -4
  12. package/build/esm/src/common/help.d.ts +1 -1
  13. package/build/esm/src/common/help.js +2 -2
  14. package/build/esm/src/common/jsx.d.ts +2 -3
  15. package/build/esm/src/common/jsx.js +70 -75
  16. package/build/esm/src/common/paths.d.ts +0 -1
  17. package/build/esm/src/common/paths.js +3 -3
  18. package/build/esm/src/common/watch.d.ts +0 -1
  19. package/build/esm/src/common/watch.js +4 -1
  20. package/build/esm/src/inflate/inflate-sea.js +35 -24
  21. package/build/esm/src/inflate/inflate.js +4 -4
  22. package/build/esm/src/inflate/setup-auth.js +1 -1
  23. package/build/esm/src/inflate/setup-cors.js +1 -1
  24. package/build/esm/src/inflate/setup-db.js +2 -2
  25. package/build/esm/src/inflate/setup-error.js +1 -1
  26. package/build/esm/src/inflate/setup-http.js +16 -16
  27. package/build/esm/src/inflate/setup-log.js +1 -1
  28. package/build/esm/src/inflate/setup-middleware.js +1 -1
  29. package/build/esm/src/inflate/setup-server-config.js +1 -1
  30. package/build/esm/src/inflate/setup-ws.js +1 -1
  31. package/build/esm/src/inflate/setup.doc.d.ts +2 -2
  32. package/build/esm/src/inflate/setup.doc.js +23 -2
  33. package/build/esm/src/inflate/utils/sea-utils.js +2 -2
  34. package/build/esm/src/lib.d.ts +10 -1
  35. package/build/esm/src/lib.js +16 -1
  36. package/build/esm/src/main.js +2 -1
  37. package/build/esm/src/services/app.d.ts +1 -0
  38. package/build/esm/src/services/app.js +4 -5
  39. package/build/esm/src/services/migrations.js +2 -2
  40. package/build/esm/src/services/utils/jwt.d.ts +2 -0
  41. package/build/esm/src/services/utils/jwt.js +23 -0
  42. package/build/esm/src/services/utils/middleware.d.ts +9 -0
  43. package/build/esm/src/services/utils/middleware.js +9 -0
  44. package/build/esm/src/services/utils/server-interface.js +33 -4
  45. package/build/esm/src/types.d.ts +50 -83
  46. package/build/lib.cjs +15694 -15619
  47. package/package.json +6 -8
  48. package/sea/basic-compile.base64.sh +1 -1
  49. package/sea/basic-compile.sh +1 -1
  50. package/sea/install-nodejs.sh +1 -1
  51. package/sea/node.version.tag +1 -1
  52. package/.eslintrc +0 -15
  53. package/build/esm/editor/auth.d.ts +0 -6
  54. package/build/esm/editor/auth.js +0 -41
  55. package/build/esm/editor/common/admin-interface.d.ts +0 -36
  56. package/build/esm/editor/common/admin-interface.js +0 -44
  57. package/build/esm/editor/common/constants.d.ts +0 -4
  58. package/build/esm/editor/common/constants.js +0 -20
  59. package/build/esm/editor/common/constants.server.d.ts +0 -2
  60. package/build/esm/editor/common/constants.server.js +0 -4
  61. package/build/esm/editor/common/editor-index.d.ts +0 -2
  62. package/build/esm/editor/common/editor-index.js +0 -14
  63. package/build/esm/editor/common/html-encode.d.ts +0 -1
  64. package/build/esm/editor/common/html-encode.js +0 -14
  65. package/build/esm/editor/common/log-socket.d.ts +0 -15
  66. package/build/esm/editor/common/log-socket.js +0 -70
  67. package/build/esm/editor/common/templates.d.ts +0 -11
  68. package/build/esm/editor/common/templates.js +0 -477
  69. package/build/esm/editor/components/api-preview.d.ts +0 -11
  70. package/build/esm/editor/components/api-preview.js +0 -90
  71. package/build/esm/editor/components/editor.d.ts +0 -16
  72. package/build/esm/editor/components/editor.js +0 -365
  73. package/build/esm/editor/components/file-browser.d.ts +0 -37
  74. package/build/esm/editor/components/file-browser.js +0 -126
  75. package/build/esm/editor/components/file-editor-toolbar.d.ts +0 -22
  76. package/build/esm/editor/components/file-editor-toolbar.js +0 -93
  77. package/build/esm/editor/components/file-editor.d.ts +0 -32
  78. package/build/esm/editor/components/file-editor.js +0 -59
  79. package/build/esm/editor/components/filter-query.d.ts +0 -1
  80. package/build/esm/editor/components/filter-query.js +0 -22
  81. package/build/esm/editor/components/highlight-text-area.d.ts +0 -11
  82. package/build/esm/editor/components/highlight-text-area.js +0 -125
  83. package/build/esm/editor/components/log-viewer.d.ts +0 -6
  84. package/build/esm/editor/components/log-viewer.js +0 -69
  85. package/build/esm/editor/components/new-file.d.ts +0 -10
  86. package/build/esm/editor/components/new-file.js +0 -117
  87. package/build/esm/editor/components/scroll-query.d.ts +0 -7
  88. package/build/esm/editor/components/scroll-query.js +0 -21
  89. package/build/esm/editor/components/start-page.d.ts +0 -13
  90. package/build/esm/editor/components/start-page.js +0 -30
  91. package/build/esm/editor/http/admin/editor/api/fs/delete.api.d.ts +0 -3
  92. package/build/esm/editor/http/admin/editor/api/fs/delete.api.js +0 -29
  93. package/build/esm/editor/http/admin/editor/api/fs/read.api.d.ts +0 -5
  94. package/build/esm/editor/http/admin/editor/api/fs/read.api.js +0 -49
  95. package/build/esm/editor/http/admin/editor/api/fs/rename.api.d.ts +0 -4
  96. package/build/esm/editor/http/admin/editor/api/fs/rename.api.js +0 -39
  97. package/build/esm/editor/http/admin/editor/api/fs/scan.api.d.ts +0 -26
  98. package/build/esm/editor/http/admin/editor/api/fs/scan.api.js +0 -149
  99. package/build/esm/editor/http/admin/editor/api/fs/write.api.d.ts +0 -3
  100. package/build/esm/editor/http/admin/editor/api/fs/write.api.js +0 -38
  101. package/build/esm/editor/http/admin/editor/api/server/reload.api.d.ts +0 -10
  102. package/build/esm/editor/http/admin/editor/api/server/reload.api.js +0 -46
  103. package/build/esm/editor/http/admin/editor/api/server/restart.api.d.ts +0 -10
  104. package/build/esm/editor/http/admin/editor/api/server/restart.api.js +0 -45
  105. package/build/esm/editor/http/admin/editor/editor.d.ts +0 -1
  106. package/build/esm/editor/http/admin/editor/editor.js +0 -7
  107. package/build/esm/editor/http/admin/editor/index.api.d.ts +0 -3
  108. package/build/esm/editor/http/admin/editor/index.api.js +0 -21
  109. package/build/esm/editor/server.d.ts +0 -3
  110. package/build/esm/editor/server.js +0 -49
  111. package/build/esm/editor/ws.d.ts +0 -3
  112. package/build/esm/editor/ws.js +0 -11
  113. package/build/esm/src/services/globals.d.ts +0 -3
  114. package/build/esm/src/services/globals.js +0 -182
  115. package/build/jsx.dom.js +0 -1587
  116. package/build/postject.base64.cjs +0 -1
  117. package/editor/auth.ts +0 -51
  118. package/editor/common/admin-interface.ts +0 -84
  119. package/editor/common/constants.server.ts +0 -5
  120. package/editor/common/constants.ts +0 -21
  121. package/editor/common/editor-index.tsx +0 -17
  122. package/editor/common/html-encode.ts +0 -14
  123. package/editor/common/log-socket.tsx +0 -85
  124. package/editor/common/templates.ts +0 -481
  125. package/editor/components/api-preview.tsx +0 -116
  126. package/editor/components/editor.tsx +0 -494
  127. package/editor/components/file-browser.tsx +0 -308
  128. package/editor/components/file-editor-toolbar.tsx +0 -191
  129. package/editor/components/file-editor.tsx +0 -122
  130. package/editor/components/filter-query.tsx +0 -22
  131. package/editor/components/highlight-text-area.tsx +0 -145
  132. package/editor/components/log-viewer.tsx +0 -110
  133. package/editor/components/new-file.tsx +0 -169
  134. package/editor/components/scroll-query.tsx +0 -22
  135. package/editor/components/start-page.tsx +0 -49
  136. package/editor/http/admin/editor/api/fs/delete.api.tsx +0 -32
  137. package/editor/http/admin/editor/api/fs/read.api.tsx +0 -55
  138. package/editor/http/admin/editor/api/fs/rename.api.tsx +0 -41
  139. package/editor/http/admin/editor/api/fs/scan.api.tsx +0 -181
  140. package/editor/http/admin/editor/api/fs/write.api.tsx +0 -41
  141. package/editor/http/admin/editor/api/server/reload.api.ts +0 -53
  142. package/editor/http/admin/editor/api/server/restart.api.tsx +0 -52
  143. package/editor/http/admin/editor/editor.tsx +0 -8
  144. package/editor/http/admin/editor/index.api.tsx +0 -39
  145. package/editor/server.ts +0 -57
  146. package/editor/ws.ts +0 -15
  147. package/sea/types.json +0 -1
  148. package/src/bin/compile.ts +0 -35
  149. package/src/bin/doc-md.ts +0 -210
  150. package/src/bin/generate-doc.ts +0 -64
  151. package/src/bin/test.ts +0 -92
  152. package/src/bin/types.ts +0 -29
  153. package/src/cluster.ts +0 -27
  154. package/src/common/arguments.ts +0 -733
  155. package/src/common/assets.ts +0 -128
  156. package/src/common/checksum.ts +0 -58
  157. package/src/common/constants.ts +0 -18
  158. package/src/common/content-type.ts +0 -84
  159. package/src/common/esbuild.ts +0 -94
  160. package/src/common/exit.ts +0 -91
  161. package/src/common/fs.ts +0 -82
  162. package/src/common/help.ts +0 -60
  163. package/src/common/jsx.ts +0 -547
  164. package/src/common/jwt.ts +0 -85
  165. package/src/common/paths.ts +0 -107
  166. package/src/common/watch.ts +0 -85
  167. package/src/inflate/inflate-sea.ts +0 -226
  168. package/src/inflate/inflate.ts +0 -101
  169. package/src/inflate/md.ts +0 -25
  170. package/src/inflate/setup-auth.ts +0 -41
  171. package/src/inflate/setup-cors.ts +0 -41
  172. package/src/inflate/setup-db.ts +0 -117
  173. package/src/inflate/setup-error.ts +0 -44
  174. package/src/inflate/setup-http.ts +0 -704
  175. package/src/inflate/setup-log.ts +0 -45
  176. package/src/inflate/setup-middleware.ts +0 -47
  177. package/src/inflate/setup-server-config.ts +0 -48
  178. package/src/inflate/setup-test.ts +0 -23
  179. package/src/inflate/setup-ws.ts +0 -50
  180. package/src/inflate/setup.doc.ts +0 -68
  181. package/src/inflate/utils/sea-utils.ts +0 -14
  182. package/src/lib.ts +0 -19
  183. package/src/main.ts +0 -100
  184. package/src/services/app.ts +0 -698
  185. package/src/services/editor.tsx +0 -101
  186. package/src/services/globals.ts +0 -186
  187. package/src/services/hot-reload.ts +0 -51
  188. package/src/services/migrations.ts +0 -68
  189. package/src/services/utils/admin-interface.ts +0 -37
  190. package/src/services/utils/cache.ts +0 -88
  191. package/src/services/utils/cluster-cache.ts +0 -230
  192. package/src/services/utils/cluster-ws.ts +0 -202
  193. package/src/services/utils/db-manager.ts +0 -92
  194. package/src/services/utils/get-route.ts +0 -70
  195. package/src/services/utils/log-transport.ts +0 -81
  196. package/src/services/utils/log.ts +0 -92
  197. package/src/services/utils/server-interface.ts +0 -92
  198. package/src/services/utils/websocketmanager.ts +0 -157
  199. package/src/types/@esbuild.d.ts +0 -1
  200. package/src/types/@miqro/core.d.ts +0 -2
  201. package/src/types/@miqro/jsx.d.ts +0 -2
  202. package/src/types/@miqro/parser.d.ts +0 -2
  203. package/src/types/@miqro/query.d.ts +0 -2
  204. package/src/types/@miqro/request.d.ts +0 -2
  205. package/src/types/@miqro/test.d.ts +0 -2
  206. package/src/types/@miqro.d.ts +0 -1
  207. package/src/types/@types.d.ts +0 -1
  208. package/src/types/browser.globals.d.ts +0 -1
  209. package/src/types/cookie.d.ts +0 -2
  210. package/src/types/globals.d.ts +0 -2
  211. package/src/types/jose.d.ts +0 -2
  212. package/src/types/jsx.globals.d.ts +0 -38
  213. package/src/types/miqro.d.ts +0 -228
  214. package/src/types/postject.d.ts +0 -1
  215. package/src/types/server.globals.d.ts +0 -47
  216. package/src/types.ts +0 -304
  217. package/tsconfig.json +0 -35
@@ -1,494 +0,0 @@
1
- import { FileEditor } from "./file-editor.js";
2
- import { NewFile } from "./new-file.js";
3
- import { useScroll } from "./scroll-query.js";
4
- import { useFilterQuery } from "./filter-query.js";
5
- import { FileBrowser } from "./file-browser.js";
6
- import { StartPage } from "./start-page.js";
7
- import { BASEEDITOR_PATH } from "../common/constants.js";
8
- import { LogViewer } from "./log-viewer.js";
9
- import { useLogSocket } from "../common/log-socket.js";
10
-
11
- function InflateError2Map(errors: {
12
- filePath: string;
13
- error: string;
14
- }[]) {
15
- const errorMap: {
16
- [filePath: string]: {
17
- error: string
18
- };
19
- } = {};
20
- for (const e of errors) {
21
- const filePath = e.filePath;
22
- const error = e.error;
23
- errorMap[filePath] = {
24
- error
25
- };
26
- }
27
- return errorMap;
28
- }
29
-
30
- export function Editor(props: { disablelog?: boolean; disablepreview?: boolean; disablereload?: boolean; migrations: string; services: string; reloadstring: string; files: string; initialcurrent: string; classname?: string; errors: string }) {
31
- //console.dir(props);
32
- const logSocket = useLogSocket({
33
- disableLog: (props as any).disablelog === "true" || props.disablelog === true ? true : false
34
- });
35
-
36
- const [services, setservices] = jsx.useState<string[]>(JSON.parse(props.services));
37
- const [collapsed, setCollapsed] = jsx.useState<{
38
- [dir: string]: boolean
39
- }>((() => {
40
- const ret: { [dir: string]: boolean } = {};
41
- services.forEach(service => {
42
- ret[`${service}/`] = false;
43
- })
44
- return ret;
45
- })());
46
-
47
- /*const [panelVisible, setpanelVisible] = jsx.useState<{
48
- [panel: string]: boolean | undefined;
49
- }>({ right: false, bottom: false });*/
50
-
51
- const [rightPanelVisible, setRightPanelVisible] = jsx.useQuery("right-panel", "0");
52
- const [leftPanelVisible, setLeftPanelVisible] = jsx.useQuery("left-panel", "1");
53
- const [bottomPanelVisible, setBottomPanelVisible] = jsx.useQuery("bottom-panel", "0");
54
-
55
- const [migrations, setmigrations] = jsx.useState<string[]>(JSON.parse(props.migrations));
56
- const [files, setfiles] = jsx.useState(JSON.parse(props.files) as {
57
- filePath: string;
58
- language: string;
59
- previewPath?: string;
60
- dirs: string[];
61
- apiPreview?: {
62
- path: string;
63
- method: string;
64
- }[];
65
- content?: string;
66
- fileName: string;
67
- }[]);
68
- const [reloadString, setreloadString] = jsx.useState<string>(props.reloadstring);
69
- const [changed, setchanged] = jsx.useState<{
70
- [filePath: string]: string | null;
71
- }>({});
72
- const [errors, seterrors] = jsx.useState<{
73
- [filePath: string]: {
74
- error: string
75
- };
76
- }>(InflateError2Map(JSON.parse(props.errors)));
77
- const [newFileDialogShow, setnewFileDialogShow] = jsx.useState<boolean>(false);
78
- const [filter, setfilter] = useFilterQuery();
79
-
80
- const refresh = jsx.useRefresh();
81
- const [opened, setopened] = jsx.useState<{
82
- [filePath: string]: {
83
- filePath: string;
84
- fileName: string;
85
- language: string;
86
- previewPath?: string;
87
- apiPreview?: {
88
- path: string;
89
- method: string;
90
- }[];
91
- content: string | null;
92
- error?: {
93
- message: string;
94
- }
95
- }
96
- }>({});
97
- const [current, setcurrent] = jsx.useQuery("current", props.initialcurrent ? props.initialcurrent : "");
98
- const [_, setScroll] = useScroll();
99
-
100
- if (current instanceof Array) {
101
- setcurrent(current[0]);
102
- } else if (current) {
103
- if (!opened[current]) {
104
- const file = files.filter(file => file.filePath === current)[0];
105
- if (!file) {
106
- setcurrent("");
107
- } else {
108
- openFile(file.filePath);
109
- }
110
- }
111
- }
112
-
113
- /*useEffect(() => {
114
- for (const service of services) {
115
- if (collapsed[`${service}/`] === undefined) {
116
- collapsed[`${service}/`] = true;
117
- refresh();
118
- }
119
- }
120
- }, services);*/
121
-
122
- function openFile(filePath: string) {
123
- console.log("open [%s]", filePath);
124
- const isOpen = opened[filePath];
125
- setScroll({
126
- scrollLeft: 0,
127
- scrollTop: 0
128
- });
129
- if (!isOpen) {
130
- const file = files.filter(file => file.filePath === filePath)[0];
131
- if (!file) {
132
- throw new Error("cannot find reference to file [" + filePath + "]");
133
- }
134
- opened[file.filePath] = {
135
- content: null,
136
- ...file
137
- };
138
- changed[file.filePath] = null;
139
-
140
- setopened(opened);
141
-
142
- if (opened[file.filePath].content === null && (globalThis.window) !== undefined) {
143
- if (opened[file.filePath].language !== "binary") {
144
- fetch(BASEEDITOR_PATH + "/api/fs/read", {
145
- method: "POST",
146
- headers: {
147
- ["content-type"]: "application/json"
148
- },
149
- body: JSON.stringify({
150
- path: file.filePath
151
- })
152
- }).then(response => {
153
-
154
- if (response.ok) {
155
- response.json().then(json => {
156
- const contents = json.contents;
157
- if (opened[file.filePath]) {
158
- opened[file.filePath].content = contents;
159
- changed[file.filePath] = contents;
160
- setopened(opened);
161
- setchanged(changed);
162
- refresh();
163
- }
164
- });
165
- }
166
- })
167
- } else {
168
- opened[file.filePath].content = "";
169
- changed[file.filePath] = "";
170
- setopened(opened);
171
- refresh();
172
- }
173
- }
174
- }
175
- setcurrent(filePath);
176
- }
177
-
178
- function closeFile(filePath: string) {
179
- setScroll({
180
- scrollTop: 0,
181
- scrollLeft: 0
182
- })
183
- console.log("closing [%s]", filePath);
184
- //console.log("current [%s]", current);
185
- if (filePath === current) {
186
- setcurrent("");
187
- }
188
- delete opened[filePath];
189
- delete changed[filePath];
190
- setchanged(changed);
191
- setopened(opened);
192
- refresh();
193
- }
194
-
195
- async function scanFiles() {
196
- const r = await fetch(BASEEDITOR_PATH + "/api/fs/scan", {
197
- method: "GET"
198
- });
199
- if (r.ok) {
200
- const { files, services } = await r.json();
201
- setfiles(files);
202
- setservices(services);
203
- for (const file of files) {
204
- if (opened[file.filePath]) {
205
- opened[file.filePath] = {
206
- content: opened[file.filePath].content,
207
- ...file
208
- };
209
- }
210
- }
211
- }
212
- }
213
-
214
- function isDirCollapsed(dir: string) {
215
- console.log("isDirCollapsed [%s]", dir);
216
- if (dir === "" || filter !== "") {
217
- return false;
218
- }
219
- return collapsed[dir] || collapsed[dir] === undefined ? true : false;
220
- //return collapsed[dir] ? false : true;
221
- }
222
-
223
- function toggleCollapseDir(dir: string) {
224
- console.log("toggleCollapseDir [%s]", dir);
225
- collapsed[dir] = isDirCollapsed(dir) ? false : true;
226
- setCollapsed(collapsed);
227
- refresh();
228
- }
229
-
230
- async function deleteFile(file: string) {
231
- console.log("deleteFile [%s]", file);
232
- const r = await fetch(BASEEDITOR_PATH + "/api/fs/delete", {
233
- method: "POST",
234
- headers: {
235
- ["content-type"]: "application/json"
236
- },
237
- body: JSON.stringify({
238
- path: file
239
- })
240
- });
241
- if (r.ok) {
242
- await scanFiles();
243
- if (opened[file]) {
244
- closeFile(file);
245
- }
246
- }
247
- }
248
-
249
- async function renameFile(file: string, newName: string) {
250
- console.log("renameFile [%s] to [%s]", file, newName);
251
- if (opened[file]) {
252
- const r = await fetch(BASEEDITOR_PATH + "/api/fs/rename", {
253
- method: "POST",
254
- headers: {
255
- ["content-type"]: "application/json"
256
- },
257
- body: JSON.stringify({
258
- path: file,
259
- newName
260
- })
261
- });
262
- if (r.ok) {
263
- const fileO = opened[file];
264
- const changeO = changed[file];
265
- fileO.filePath = newName;
266
- delete changed[file];
267
- delete opened[file];
268
- opened[newName] = fileO;
269
- changed[newName] = changeO;
270
-
271
- await scanFiles();
272
-
273
- setopened(opened);
274
- setchanged(changed);
275
- if (current === file) {
276
- setcurrent(newName);
277
- }
278
- refresh();
279
- }
280
- }
281
- }
282
-
283
- async function saveFile(file: string) {
284
- console.log("saveFile [%s]", file);
285
- const contents = changed[file];
286
- if (opened[file] && contents !== undefined && contents !== null) {
287
- const r = await fetch(BASEEDITOR_PATH + "/api/fs/write", {
288
- method: "POST",
289
- headers: {
290
- ["content-type"]: "application/json"
291
- },
292
- body: JSON.stringify({
293
- path: file,
294
- contents,
295
- override: true
296
- })
297
- });
298
- if (r.ok) {
299
- opened[file].content = contents;
300
- setopened(opened);
301
- setchanged(changed);
302
- refresh();
303
- }
304
- }
305
- }
306
-
307
- async function reloadServer() {
308
- const r = await fetch(BASEEDITOR_PATH + "/api/server/reload", {
309
- method: "POST"
310
- });
311
- if (r.ok) {
312
- const reloadResponse = await r.json();
313
- if (reloadResponse.errors && reloadResponse.errors.length > 0) {
314
- seterrors(InflateError2Map(reloadResponse.errors));
315
- setreloadString(reloadResponse.reloadString);
316
- refresh();
317
- } else {
318
- setreloadString(reloadResponse.reloadString);
319
- seterrors({});
320
- refresh();
321
- }
322
- setmigrations(reloadResponse.migrations);
323
- await scanFiles();
324
- }
325
- }
326
-
327
- function setLanguage(file: string, newLanguage: string) {
328
- if (opened[file]) {
329
- opened[file].language = newLanguage;
330
- setopened(opened);
331
- refresh();
332
- }
333
- }
334
-
335
- function hasFileContentChanged(filePath: string) {
336
- if (!opened[filePath]) {
337
- return false;
338
- }
339
- return changed[filePath] !== opened[filePath].content
340
- }
341
-
342
- function isPanelVisible(panel: string) {
343
- switch (panel) {
344
- case "left":
345
- return leftPanelVisible === "1";
346
- case "bottom":
347
- return bottomPanelVisible === "1";
348
- case "right":
349
- return rightPanelVisible === "1";
350
- default:
351
- return true;
352
- }
353
- //return panelVisible[panel] || panelVisible[panel] === undefined ? true : false;
354
- }
355
-
356
- function togglePanel(panel: string) {
357
- console.log("togglePanel [%s]", panel);
358
- /*panelVisible[panel] = !isPanelVisible(panel);
359
- setpanelVisible(panelVisible);
360
- refresh();*/
361
- switch (panel) {
362
- case "left":
363
- return setLeftPanelVisible(isPanelVisible(panel) ? "0" : "1");
364
- case "bottom":
365
- return setBottomPanelVisible(isPanelVisible(panel) ? "0" : "1");
366
- case "right":
367
- return setRightPanelVisible(isPanelVisible(panel) ? "0" : "1");
368
- default:
369
- return;
370
- }
371
- }
372
-
373
- const openedFile = opened[String(current)];
374
-
375
- //console.log("Editor [%s]", openedFile?.filePath);
376
-
377
- return <div class="editor">
378
- <div class={`editor-firstrow${!isPanelVisible("bottom") ? " bottom-panel-hidden" : ""}`}>
379
- <NewFile
380
- migrations={migrations}
381
- services={services}
382
- open={newFileDialogShow}
383
- ondone={async (path) => {
384
- setnewFileDialogShow(false);
385
- if (path) {
386
- await scanFiles();
387
- //await reloadServer();
388
- }
389
- }} />
390
- <FileBrowser
391
- disableLog={props.disablelog}
392
- disablePreview={props.disablepreview}
393
- disableReload={props.disablereload}
394
- togglePanel={togglePanel}
395
- isPanelVisible={isPanelVisible}
396
- opened={Object.keys(opened).sort().map(o => opened[o])}
397
- isDirCollapsed={isDirCollapsed}
398
- toggleCollapseDir={toggleCollapseDir}
399
- migrations={migrations}
400
- hasErrors={(file) => errors[file] ? true : false}
401
- reloadServer={reloadServer}
402
- closeAll={() => {
403
- const openedList = Object.keys(opened);
404
- for (const o of openedList) {
405
- closeFile(o);
406
- }
407
- }}
408
- closeFile={closeFile}
409
- current={current ? String(current) : ""}
410
- files={files}
411
- filter={filter}
412
- hasFileContentChanged={hasFileContentChanged}
413
- isOpen={(file) => opened[file] !== undefined}
414
- openFile={openFile}
415
- saveAll={async () => {
416
- const openedList = Object.keys(opened);
417
- for (const o of openedList) {
418
- if (hasFileContentChanged(o)) {
419
- await saveFile(o);
420
- }
421
- }
422
- //await reloadServer();
423
- }}
424
- scanFiles={scanFiles}
425
- setfilter={setfilter}
426
- showNewFile={() => {
427
- setnewFileDialogShow(true);
428
- }}
429
- />
430
- <div class={`file-editor-list${!isPanelVisible("left") ? " left-panel-hidden" : ""}${!isPanelVisible("bottom") ? " bottom-panel-hidden" : ""}`}>
431
- {!openedFile ?
432
- <StartPage
433
- disableLog={props.disablelog}
434
- disablePreview={props.disablepreview}
435
- disableReload={props.disablereload}
436
- isPanelVisible={isPanelVisible}
437
- togglePanel={togglePanel}
438
- /> :
439
- <div class="file-editor-container">
440
- <FileEditor
441
- disableLog={props.disablelog}
442
- disablePreview={props.disablepreview}
443
- disableReload={props.disablereload}
444
- isPanelVisible={isPanelVisible}
445
- togglePanel={togglePanel}
446
- reloadString={reloadString}
447
- error={errors[openedFile.filePath]?.error}
448
- changed={hasFileContentChanged(openedFile.filePath)}
449
- setlanguage={(newLanguage: string) => setLanguage(openedFile.filePath, newLanguage)}
450
- deleteFile={async () => {
451
- await deleteFile(openedFile.filePath);
452
- //await reloadServer();
453
- }}
454
- renameFile={async (newName) => {
455
- await renameFile(openedFile.filePath, newName);
456
- //await reloadServer();
457
- }}
458
- saveFile={async (reload = false) => {
459
- await saveFile(openedFile.filePath);
460
- if (reload) {
461
- await reloadServer();
462
- }
463
- //
464
- }}
465
- content={changed[openedFile.filePath] !== null ? changed[openedFile.filePath] : opened[openedFile.filePath].content}
466
- current={current === openedFile.filePath}
467
- revertFile={() => {
468
- changed[openedFile.filePath] = openedFile.content;
469
- setchanged(changed);
470
- refresh();
471
- }}
472
- contentchange={(content) => {
473
- changed[openedFile.filePath] = content;
474
- setopened(opened);
475
- refresh();
476
- }}
477
- closeFile={() => {
478
- closeFile(openedFile.filePath);
479
- }}
480
- path={openedFile.filePath}
481
- previewPath={openedFile.previewPath}
482
- apiPreview={openedFile.apiPreview}
483
- language={opened[openedFile.filePath].language} />
484
- </div>}
485
- </div>
486
- </div>
487
- <div class="editor-bottom-panel" style={`${!isPanelVisible("bottom") ? "display: none;" : ""}`}>
488
- <LogViewer socket={logSocket} />
489
- </div>
490
- </div>
491
- }
492
-
493
- Editor.asFragment = true;
494
- Editor.shadowInit = false;