underpost 2.7.1 → 2.7.3

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 (214) hide show
  1. package/.dockerignore +13 -13
  2. package/.env.development +7 -7
  3. package/.env.production +7 -7
  4. package/.env.test +7 -7
  5. package/.github/workflows/publish.yml +26 -0
  6. package/.github/workflows/test.yml +80 -0
  7. package/.nycrc +9 -9
  8. package/.prettierignore +12 -12
  9. package/.prettierrc +9 -9
  10. package/.vscode/extensions.json +72 -72
  11. package/.vscode/settings.json +100 -99
  12. package/Dockerfile +89 -89
  13. package/LICENSE +21 -21
  14. package/README.md +96 -96
  15. package/bin/db.js +172 -119
  16. package/bin/deploy.js +607 -661
  17. package/bin/file.js +93 -92
  18. package/bin/index.js +76 -53
  19. package/bin/ssl.js +55 -64
  20. package/bin/util.js +182 -182
  21. package/bin/vs.js +35 -35
  22. package/conf.js +251 -249
  23. package/docker-compose.yml +67 -67
  24. package/jsconfig.json +7 -7
  25. package/jsdoc.json +32 -32
  26. package/nodemon.json +6 -6
  27. package/package.json +137 -132
  28. package/prometheus.yml +36 -36
  29. package/setup.sh +24 -24
  30. package/src/api/core/core.controller.js +69 -69
  31. package/src/api/core/core.model.js +11 -11
  32. package/src/api/core/core.router.js +23 -23
  33. package/src/api/core/core.service.js +29 -29
  34. package/src/api/crypto/crypto.controller.js +51 -51
  35. package/src/api/crypto/crypto.model.js +23 -23
  36. package/src/api/crypto/crypto.router.js +20 -20
  37. package/src/api/crypto/crypto.service.js +64 -64
  38. package/src/api/default/default.controller.js +69 -69
  39. package/src/api/default/default.model.js +20 -20
  40. package/src/api/default/default.router.js +23 -23
  41. package/src/api/default/default.service.js +31 -31
  42. package/src/api/file/file.controller.js +53 -51
  43. package/src/api/file/file.model.js +19 -19
  44. package/src/api/file/file.router.js +21 -20
  45. package/src/api/file/file.service.js +76 -70
  46. package/src/api/instance/instance.controller.js +69 -69
  47. package/src/api/instance/instance.model.js +36 -36
  48. package/src/api/instance/instance.router.js +33 -33
  49. package/src/api/instance/instance.service.js +48 -48
  50. package/src/api/test/test.controller.js +59 -59
  51. package/src/api/test/test.model.js +14 -14
  52. package/src/api/test/test.router.js +21 -21
  53. package/src/api/test/test.service.js +35 -35
  54. package/src/api/user/user.build.js +16 -0
  55. package/src/api/user/user.controller.js +70 -70
  56. package/src/api/user/user.model.js +65 -65
  57. package/src/api/user/user.router.js +345 -345
  58. package/src/api/user/user.service.js +479 -479
  59. package/src/api.js +23 -23
  60. package/src/client/Default.index.js +40 -40
  61. package/src/client/components/core/Account.js +290 -290
  62. package/src/client/components/core/AgGrid.js +160 -160
  63. package/src/client/components/core/Auth.js +19 -19
  64. package/src/client/components/core/Badge.js +32 -32
  65. package/src/client/components/core/{BlockChain.js → Blockchain.js} +41 -41
  66. package/src/client/components/core/Blog.js +9 -9
  67. package/src/client/components/core/BtnIcon.js +101 -94
  68. package/src/client/components/core/CalendarCore.js +458 -319
  69. package/src/client/components/core/Chat.js +64 -64
  70. package/src/client/components/core/ColorPalette.js +5267 -5267
  71. package/src/client/components/core/CommonJs.js +735 -732
  72. package/src/client/components/core/Content.js +193 -49
  73. package/src/client/components/core/Css.js +1064 -1027
  74. package/src/client/components/core/CssCore.js +817 -796
  75. package/src/client/components/core/D3Chart.js +44 -44
  76. package/src/client/components/core/Docs.js +229 -229
  77. package/src/client/components/core/DropDown.js +164 -164
  78. package/src/client/components/core/EventsUI.js +46 -54
  79. package/src/client/components/core/FileExplorer.js +699 -624
  80. package/src/client/components/core/FullScreen.js +45 -45
  81. package/src/client/components/core/Input.js +346 -259
  82. package/src/client/components/core/JoyStick.js +77 -77
  83. package/src/client/components/core/Keyboard.js +73 -73
  84. package/src/client/components/core/LoadingAnimation.js +179 -157
  85. package/src/client/components/core/LogIn.js +187 -181
  86. package/src/client/components/core/LogOut.js +58 -52
  87. package/src/client/components/core/Logger.js +26 -26
  88. package/src/client/components/core/Modal.js +1612 -1596
  89. package/src/client/components/core/NotificationManager.js +84 -84
  90. package/src/client/components/core/Panel.js +613 -413
  91. package/src/client/components/core/PanelForm.js +468 -0
  92. package/src/client/components/core/Polyhedron.js +162 -162
  93. package/src/client/components/core/Recover.js +204 -204
  94. package/src/client/components/core/Responsive.js +53 -53
  95. package/src/client/components/core/RichText.js +51 -27
  96. package/src/client/components/core/Router.js +76 -77
  97. package/src/client/components/core/Scroll.js +34 -0
  98. package/src/client/components/core/SignUp.js +125 -125
  99. package/src/client/components/core/SocketIo.js +72 -72
  100. package/src/client/components/core/Stream.js +113 -113
  101. package/src/client/components/core/ToggleSwitch.js +87 -87
  102. package/src/client/components/core/ToolTip.js +26 -26
  103. package/src/client/components/core/Translate.js +437 -408
  104. package/src/client/components/core/Validator.js +100 -100
  105. package/src/client/components/core/VanillaJs.js +460 -457
  106. package/src/client/components/core/Wallet.js +106 -106
  107. package/src/client/components/core/Webhook.js +25 -25
  108. package/src/client/components/core/Worker.js +272 -272
  109. package/src/client/components/default/CommonDefault.js +29 -29
  110. package/src/client/components/default/CssDefault.js +13 -13
  111. package/src/client/components/default/ElementsDefault.js +38 -38
  112. package/src/client/components/default/LogInDefault.js +41 -41
  113. package/src/client/components/default/LogOutDefault.js +28 -28
  114. package/src/client/components/default/MenuDefault.js +389 -389
  115. package/src/client/components/default/RoutesDefault.js +48 -48
  116. package/src/client/components/default/SettingsDefault.js +16 -16
  117. package/src/client/components/default/SignUpDefault.js +9 -9
  118. package/src/client/components/default/SocketIoDefault.js +54 -54
  119. package/src/client/components/default/TranslateDefault.js +7 -7
  120. package/src/client/public/default/assets/mailer/api-user-check.png +0 -0
  121. package/src/client/public/default/assets/mailer/api-user-invalid-token.png +0 -0
  122. package/src/client/public/default/assets/mailer/api-user-recover.png +0 -0
  123. package/src/client/public/default/browserconfig.xml +11 -11
  124. package/src/client/public/default/manifest.webmanifest +68 -68
  125. package/src/client/public/default/plantuml/client-conf.svg +1 -0
  126. package/src/client/public/default/plantuml/client-schema.svg +1 -0
  127. package/src/client/public/default/plantuml/cron-conf.svg +1 -0
  128. package/src/client/public/default/plantuml/cron-schema.svg +1 -0
  129. package/src/client/public/default/plantuml/server-conf.svg +1 -0
  130. package/src/client/public/default/plantuml/server-schema.svg +1 -0
  131. package/src/client/public/default/plantuml/ssr-conf.svg +1 -0
  132. package/src/client/public/default/plantuml/ssr-schema.svg +1 -0
  133. package/src/client/public/default/sitemap +147 -147
  134. package/src/client/public/default/yandex-browser-manifest.json +8 -8
  135. package/src/client/public/doc/sitemap +147 -147
  136. package/src/client/public/test/sitemap +147 -147
  137. package/src/client/services/core/core.service.js +170 -152
  138. package/src/client/services/crypto/crypto.service.js +70 -70
  139. package/src/client/services/default/default.management.js +345 -345
  140. package/src/client/services/default/default.service.js +89 -89
  141. package/src/client/services/file/file.service.js +70 -70
  142. package/src/client/services/instance/instance.management.js +74 -74
  143. package/src/client/services/instance/instance.service.js +89 -89
  144. package/src/client/services/test/test.service.js +70 -70
  145. package/src/client/services/user/user.management.js +50 -50
  146. package/src/client/services/user/user.service.js +89 -89
  147. package/src/client/ssr/Render.js +16 -16
  148. package/src/client/ssr/body-components/CacheControl.js +114 -113
  149. package/src/client/ssr/body-components/DefaultSplashScreen.js +79 -79
  150. package/src/client/ssr/email-components/DefaultRecoverEmail.js +21 -21
  151. package/src/client/ssr/email-components/DefaultVerifyEmail.js +17 -17
  152. package/src/client/ssr/head-components/Css.js +241 -241
  153. package/src/client/ssr/head-components/DefaultScripts.js +3 -3
  154. package/src/client/ssr/head-components/Microdata.js +11 -11
  155. package/src/client/ssr/head-components/Production.js +1 -1
  156. package/src/client/ssr/head-components/PwaDefault.js +59 -59
  157. package/src/client/ssr/head-components/Seo.js +14 -14
  158. package/src/client/sw/default.sw.js +201 -201
  159. package/src/client/sw/template.sw.js +84 -84
  160. package/src/client.build.js +22 -22
  161. package/src/client.dev.js +21 -21
  162. package/src/cron.js +25 -25
  163. package/src/db/DataBaseProvider.js +34 -34
  164. package/src/db/mariadb/MariaDB.js +33 -33
  165. package/src/db/mongo/MongooseDB.js +137 -46
  166. package/src/dns.js +22 -22
  167. package/src/index.js +42 -29
  168. package/src/mailer/EmailRender.js +69 -69
  169. package/src/mailer/MailerProvider.js +96 -96
  170. package/src/proxy.js +22 -22
  171. package/src/runtime/lampp/Lampp.js +115 -44
  172. package/src/runtime/nginx/Nginx.js +3 -3
  173. package/src/runtime/xampp/Xampp.js +49 -49
  174. package/src/server/auth.js +235 -204
  175. package/src/server/backup.js +101 -94
  176. package/src/server/client-build-live.js +72 -72
  177. package/src/server/client-build.js +699 -699
  178. package/src/server/client-dev-server.js +60 -58
  179. package/src/server/client-formatted.js +48 -48
  180. package/src/server/client-icons.js +149 -150
  181. package/src/server/conf.js +860 -611
  182. package/src/server/dns.js +98 -98
  183. package/src/server/downloader.js +42 -42
  184. package/src/server/logger.js +190 -180
  185. package/src/server/network.js +122 -122
  186. package/src/server/peer.js +33 -33
  187. package/src/server/process.js +66 -66
  188. package/src/server/prompt-optimizer.js +28 -28
  189. package/src/server/proxy.js +118 -118
  190. package/src/server/runtime.js +444 -393
  191. package/src/server/ssl.js +120 -107
  192. package/src/server.js +25 -25
  193. package/src/ws/IoInterface.js +45 -45
  194. package/src/ws/IoServer.js +39 -39
  195. package/src/ws/core/channels/core.ws.chat.js +23 -23
  196. package/src/ws/core/channels/core.ws.mailer.js +35 -35
  197. package/src/ws/core/channels/core.ws.stream.js +31 -31
  198. package/src/ws/core/core.ws.connection.js +28 -28
  199. package/src/ws/core/core.ws.emit.js +14 -14
  200. package/src/ws/core/core.ws.server.js +24 -24
  201. package/src/ws/core/management/core.ws.chat.js +8 -8
  202. package/src/ws/core/management/core.ws.mailer.js +16 -16
  203. package/src/ws/core/management/core.ws.stream.js +8 -8
  204. package/src/ws/default/channels/default.ws.main.js +16 -16
  205. package/src/ws/default/default.ws.connection.js +22 -22
  206. package/src/ws/default/default.ws.emit.js +14 -14
  207. package/src/ws/default/default.ws.server.js +20 -20
  208. package/src/ws/default/management/default.ws.main.js +8 -8
  209. package/startup.js +11 -11
  210. package/supervisord-openssh-server.conf +4 -4
  211. package/test/api.test.js +60 -60
  212. package/bin/dns.js +0 -1
  213. package/bin/install.js +0 -357
  214. package/bin/shortcut.js +0 -44
@@ -1,77 +1,76 @@
1
- import { titleFormatted } from './CommonJs.js';
2
- import { loggerFactory } from './Logger.js';
3
- import { getProxyPath, getQueryParams, htmls, s, setPath } from './VanillaJs.js';
4
-
5
- // Router
6
-
7
- const logger = loggerFactory(import.meta);
8
-
9
- const setDocTitle = (options = { Routes: () => {}, route: '', NameApp: '' }) => {
10
- const { Routes, route, NameApp } = options;
11
- let title = titleFormatted(Routes()[`/${route}`].title);
12
- if (Routes()[`/${route}`].upperCase) title = title.toUpperCase();
13
- htmls('title', html`${title} | ${NameApp}`);
14
- {
15
- const routeId = route === '' ? 'home' : route;
16
- if (s(`.main-btn-${routeId}`)) {
17
- if (s(`.main-btn-menu-active`)) s(`.main-btn-menu-active`).classList.remove(`main-btn-menu-active`);
18
- if (s(`.main-btn-${routeId}`)) s(`.main-btn-${routeId}`).classList.add(`main-btn-menu-active`);
19
- }
20
- }
21
- };
22
-
23
- const RouterEvents = {};
24
-
25
- const Router = function (options = { Routes: () => {}, e: new PopStateEvent(), NameApp: '' }) {
26
- const { e, Routes, NameApp } = options;
27
- const proxyPath = getProxyPath();
28
- let path = window.location.pathname;
29
- logger.info(options);
30
-
31
- for (let route of Object.keys(Routes())) {
32
- route = route.slice(1);
33
- let pushPath = `${proxyPath}${route}`;
34
-
35
- if (path[path.length - 1] !== '/') path = `${path}/`;
36
- if (pushPath[pushPath.length - 1] !== '/') pushPath = `${pushPath}/`;
37
-
38
- const routerEvent = { path, pushPath, route };
39
-
40
- logger.info(routerEvent);
41
-
42
- for (const event of Object.keys(RouterEvents)) RouterEvents[event](routerEvent);
43
-
44
- if (path === pushPath) {
45
- setDocTitle({ Routes, route, NameApp });
46
- return Routes()[`/${route}`].render();
47
- }
48
- }
49
- };
50
-
51
- const LoadRouter = function (RouterInstance) {
52
- Router(RouterInstance);
53
- window.onpopstate = (e) => Router({ ...RouterInstance, e });
54
- };
55
-
56
- const setQueryPath = (options = { path: '', queryPath: '' }, queryKey = 'p') => {
57
- const { queryPath, path } = options;
58
- const newUri = `${getProxyPath()}${path}${queryPath ? `/?${queryKey}=${queryPath}` : ''}`;
59
- const currentUri = `${window.location.pathname}${location.search}`;
60
- if (currentUri !== newUri && currentUri !== `${newUri}/`) setPath(newUri);
61
- };
62
-
63
- const listenQueryPathInstance = ({ id, routeId, event }, queryKey = 'p') => {
64
- RouterEvents[id] = ({ path, pushPath, proxyPath, route }) => {
65
- if (route === routeId) {
66
- setTimeout(() => {
67
- const path = getQueryParams()[queryKey];
68
- if (path) event(path);
69
- });
70
- }
71
- };
72
- setTimeout(() => {
73
- RouterEvents[id]({ route: routeId });
74
- });
75
- };
76
-
77
- export { Router, setDocTitle, LoadRouter, RouterEvents, setQueryPath, listenQueryPathInstance };
1
+ import { titleFormatted } from './CommonJs.js';
2
+ import { loggerFactory } from './Logger.js';
3
+ import { getProxyPath, getQueryParams, htmls, s, setPath } from './VanillaJs.js';
4
+
5
+ // Router
6
+
7
+ const logger = loggerFactory(import.meta);
8
+
9
+ const setDocTitle = (options = { Routes: () => {}, route: '', NameApp: '' }) => {
10
+ const { Routes, route, NameApp } = options;
11
+ let title = titleFormatted(Routes()[`/${route}`].title);
12
+ if (Routes()[`/${route}`].upperCase) title = title.toUpperCase();
13
+ htmls('title', html`${title} | ${NameApp}`);
14
+ {
15
+ const routeId = route === '' ? 'home' : route;
16
+ if (s(`.main-btn-${routeId}`)) {
17
+ if (s(`.main-btn-menu-active`)) s(`.main-btn-menu-active`).classList.remove(`main-btn-menu-active`);
18
+ if (s(`.main-btn-${routeId}`)) s(`.main-btn-${routeId}`).classList.add(`main-btn-menu-active`);
19
+ }
20
+ }
21
+ };
22
+
23
+ const RouterEvents = {};
24
+
25
+ const Router = function (options = { Routes: () => {}, e: new PopStateEvent(), NameApp: '' }) {
26
+ const { e, Routes, NameApp } = options;
27
+ const proxyPath = getProxyPath();
28
+ let path = window.location.pathname;
29
+ logger.info(options);
30
+
31
+ for (let route of Object.keys(Routes())) {
32
+ route = route.slice(1);
33
+ let pushPath = `${proxyPath}${route}`;
34
+
35
+ if (path[path.length - 1] !== '/') path = `${path}/`;
36
+ if (pushPath[pushPath.length - 1] !== '/') pushPath = `${pushPath}/`;
37
+
38
+ const routerEvent = { path, pushPath, route };
39
+
40
+ if (path === pushPath) {
41
+ for (const event of Object.keys(RouterEvents)) RouterEvents[event](routerEvent);
42
+ setDocTitle({ Routes, route, NameApp });
43
+ return Routes()[`/${route}`].render();
44
+ }
45
+ }
46
+ };
47
+
48
+ const LoadRouter = function (RouterInstance) {
49
+ Router(RouterInstance);
50
+ window.onpopstate = (e) => Router({ ...RouterInstance, e });
51
+ };
52
+
53
+ const setQueryPath = (options = { path: '', queryPath: '' }, queryKey = 'cid') => {
54
+ const { queryPath, path } = options;
55
+ const newUri = `${getProxyPath()}${path === 'home' ? '' : `${path}/`}${queryPath ? `?${queryKey}=${queryPath}` : ''}`;
56
+ const currentUri = `${window.location.pathname}${location.search}`;
57
+ if (currentUri !== newUri && currentUri !== `${newUri}/`) setPath(newUri);
58
+ };
59
+
60
+ const listenQueryPathInstance = ({ id, routeId, event }, queryKey = 'cid') => {
61
+ RouterEvents[id] = ({ path, pushPath, proxyPath, route }) => {
62
+ if ((route === '' && routeId === 'home') || (route && routeId && route === routeId)) {
63
+ setTimeout(() => {
64
+ const path = getQueryParams()[queryKey];
65
+ if (path) event(path);
66
+ else event('');
67
+ });
68
+ }
69
+ };
70
+ if (routeId && routeId !== 'home')
71
+ setTimeout(() => {
72
+ RouterEvents[id]({ route: routeId });
73
+ });
74
+ };
75
+
76
+ export { Router, setDocTitle, LoadRouter, RouterEvents, setQueryPath, listenQueryPathInstance };
@@ -0,0 +1,34 @@
1
+ import { s } from './VanillaJs.js';
2
+
3
+ const Scroll = {
4
+ data: {},
5
+ init: function (selector) {
6
+ s(selector).addEventListener('scroll', Scroll.scrollHandler);
7
+ Scroll.data[selector] = {
8
+ element: s(selector),
9
+ };
10
+ return Scroll.data[selector];
11
+ },
12
+ getScrollPosition: function (selector) {
13
+ // Scroll.data[selector].element.clientHeight -
14
+ return Scroll.data[selector].element.scrollTop;
15
+ },
16
+ scrollHandler: async function () {
17
+ for (const selector in Scroll.data) await Scroll.data[selector].callback(Scroll.getScrollPosition(selector));
18
+ },
19
+ addEvent: function (selector = '', callback = () => {}) {
20
+ Scroll.data[selector].callback = callback;
21
+ },
22
+ removeEvent: function (selector) {
23
+ delete Scroll.data[selector];
24
+ },
25
+ to: function (elector = '', options = { top: 100, left: 100, behavior: 'smooth' }) {
26
+ Scroll.data[selector].element.scrollTo({
27
+ top: options.top || Scroll.getScrollPosition(selector),
28
+ left: options.left || 0,
29
+ behavior: options.behavior || 'smooth',
30
+ });
31
+ },
32
+ };
33
+
34
+ export { Scroll };
@@ -1,125 +1,125 @@
1
- import { UserService } from '../../services/user/user.service.js';
2
- import { BtnIcon } from './BtnIcon.js';
3
- import { EventsUI } from './EventsUI.js';
4
- import { Input } from './Input.js';
5
- import { LogIn } from './LogIn.js';
6
- import { NotificationManager } from './NotificationManager.js';
7
- import { Translate } from './Translate.js';
8
- import { Validator } from './Validator.js';
9
- import { s } from './VanillaJs.js';
10
-
11
- const SignUp = {
12
- Event: {},
13
- Trigger: async function (options) {
14
- for (const eventKey of Object.keys(this.Event)) await this.Event[eventKey](options);
15
- },
16
- Render: async function (options = { bottomRender: async () => '' }) {
17
- setTimeout(async () => {
18
- const formData = [
19
- {
20
- model: 'username',
21
- id: `sign-up-username`,
22
- rules: [{ type: 'isEmpty' }, { type: 'isLength', options: { min: 2, max: 20 } }],
23
- },
24
- { model: 'email', id: `sign-up-email`, rules: [{ type: 'isEmpty' }, { type: 'isEmail' }] },
25
- {
26
- model: 'password',
27
- id: `sign-up-password`,
28
- rules: [{ type: 'isStrongPassword' }],
29
- },
30
- {
31
- id: `sign-up-repeat-password`,
32
- rules: [{ type: 'isEmpty' }, { type: 'passwordMismatch', options: `sign-up-password` }],
33
- },
34
- ];
35
- const validators = await Validator.instance(formData);
36
-
37
- EventsUI.onClick(`.btn-sign-up`, async (e) => {
38
- e.preventDefault();
39
- const { errorMessage } = await validators();
40
- if (errorMessage) return;
41
- const body = {};
42
- for (const inputData of formData) {
43
- if ('model' in inputData) body[inputData.model] = s(`.${inputData.id}`).value;
44
- }
45
- const result = await UserService.post({ body });
46
- NotificationManager.Push({
47
- html:
48
- typeof result.data === 'string'
49
- ? result.data
50
- : result.status === 'success'
51
- ? Translate.Render(`success-register-user`)
52
- : Translate.Render(`no-valid-register`),
53
- status: result.status,
54
- });
55
- if (result.status === 'success') {
56
- await this.Trigger(result.data);
57
- await LogIn.Trigger(result.data);
58
- }
59
- });
60
- s(`.btn-sign-up-i-have-account`).onclick = () => {
61
- s(`.main-btn-log-in`).click();
62
- };
63
- });
64
- return html`
65
- ${await BtnIcon.Render({
66
- class: 'section-mp form-button btn-sign-up-i-have-account',
67
- label: html`<i class="fas fa-sign-in-alt"></i> ${Translate.Render('i-have-account')}<br />${Translate.Render(
68
- 'log-in',
69
- )}`,
70
- type: 'button',
71
- })}
72
- <form class="in">
73
- <div class="in">
74
- ${await Input.Render({
75
- id: `sign-up-username`,
76
- type: 'text',
77
- label: html`<i class="fa-solid fa-pen-to-square"></i> ${Translate.Render('username')}`,
78
- containerClass: 'inl section-mp width-mini-box input-container',
79
- placeholder: true,
80
- })}
81
- </div>
82
- <div class="in">
83
- ${await Input.Render({
84
- id: `sign-up-email`,
85
- type: 'email',
86
- label: html`<i class="fa-solid fa-envelope"></i> ${Translate.Render('email')}`,
87
- containerClass: 'inl section-mp width-mini-box input-container',
88
- placeholder: true,
89
- autocomplete: 'email',
90
- })}
91
- </div>
92
- <div class="in">
93
- ${await Input.Render({
94
- id: `sign-up-password`,
95
- type: 'password',
96
- autocomplete: 'new-password',
97
- label: html`<i class="fa-solid fa-lock"></i> ${Translate.Render('password')}`,
98
- containerClass: 'inl section-mp width-mini-box input-container',
99
- placeholder: true,
100
- })}
101
- </div>
102
- <div class="in">
103
- ${await Input.Render({
104
- id: `sign-up-repeat-password`,
105
- type: 'password',
106
- autocomplete: 'new-password',
107
- label: html`<i class="fa-solid fa-lock"></i> ${Translate.Render('repeat')} ${Translate.Render('password')}`,
108
- containerClass: 'inl section-mp width-mini-box input-container',
109
- placeholder: true,
110
- })}
111
- </div>
112
- ${options?.bottomRender ? await options.bottomRender() : ``}
113
- <div class="in">
114
- ${await BtnIcon.Render({
115
- class: 'section-mp form-button btn-sign-up',
116
- label: Translate.Render('sign-up'),
117
- type: 'submit',
118
- })}
119
- </div>
120
- </form>
121
- `;
122
- },
123
- };
124
-
125
- export { SignUp };
1
+ import { UserService } from '../../services/user/user.service.js';
2
+ import { BtnIcon } from './BtnIcon.js';
3
+ import { EventsUI } from './EventsUI.js';
4
+ import { Input } from './Input.js';
5
+ import { LogIn } from './LogIn.js';
6
+ import { NotificationManager } from './NotificationManager.js';
7
+ import { Translate } from './Translate.js';
8
+ import { Validator } from './Validator.js';
9
+ import { s } from './VanillaJs.js';
10
+
11
+ const SignUp = {
12
+ Event: {},
13
+ Trigger: async function (options) {
14
+ for (const eventKey of Object.keys(this.Event)) await this.Event[eventKey](options);
15
+ },
16
+ Render: async function (options = { bottomRender: async () => '' }) {
17
+ setTimeout(async () => {
18
+ const formData = [
19
+ {
20
+ model: 'username',
21
+ id: `sign-up-username`,
22
+ rules: [{ type: 'isEmpty' }, { type: 'isLength', options: { min: 2, max: 20 } }],
23
+ },
24
+ { model: 'email', id: `sign-up-email`, rules: [{ type: 'isEmpty' }, { type: 'isEmail' }] },
25
+ {
26
+ model: 'password',
27
+ id: `sign-up-password`,
28
+ rules: [{ type: 'isStrongPassword' }],
29
+ },
30
+ {
31
+ id: `sign-up-repeat-password`,
32
+ rules: [{ type: 'isEmpty' }, { type: 'passwordMismatch', options: `sign-up-password` }],
33
+ },
34
+ ];
35
+ const validators = await Validator.instance(formData);
36
+
37
+ EventsUI.onClick(`.btn-sign-up`, async (e) => {
38
+ e.preventDefault();
39
+ const { errorMessage } = await validators();
40
+ if (errorMessage) return;
41
+ const body = {};
42
+ for (const inputData of formData) {
43
+ if ('model' in inputData) body[inputData.model] = s(`.${inputData.id}`).value;
44
+ }
45
+ const result = await UserService.post({ body });
46
+ NotificationManager.Push({
47
+ html:
48
+ typeof result.data === 'string'
49
+ ? result.data
50
+ : result.status === 'success'
51
+ ? Translate.Render(`success-register-user`)
52
+ : Translate.Render(`no-valid-register`),
53
+ status: result.status,
54
+ });
55
+ if (result.status === 'success') {
56
+ await this.Trigger(result.data);
57
+ await LogIn.Trigger(result.data);
58
+ }
59
+ });
60
+ s(`.btn-sign-up-i-have-account`).onclick = () => {
61
+ s(`.main-btn-log-in`).click();
62
+ };
63
+ });
64
+ return html`
65
+ ${await BtnIcon.Render({
66
+ class: 'section-mp form-button btn-sign-up-i-have-account',
67
+ label: html`<i class="fas fa-sign-in-alt"></i> ${Translate.Render('i-have-account')}<br />${Translate.Render(
68
+ 'log-in',
69
+ )}`,
70
+ type: 'button',
71
+ })}
72
+ <form class="in">
73
+ <div class="in">
74
+ ${await Input.Render({
75
+ id: `sign-up-username`,
76
+ type: 'text',
77
+ label: html`<i class="fa-solid fa-pen-to-square"></i> ${Translate.Render('username')}`,
78
+ containerClass: 'inl section-mp width-mini-box input-container',
79
+ placeholder: true,
80
+ })}
81
+ </div>
82
+ <div class="in">
83
+ ${await Input.Render({
84
+ id: `sign-up-email`,
85
+ type: 'email',
86
+ label: html`<i class="fa-solid fa-envelope"></i> ${Translate.Render('email')}`,
87
+ containerClass: 'inl section-mp width-mini-box input-container',
88
+ placeholder: true,
89
+ autocomplete: 'email',
90
+ })}
91
+ </div>
92
+ <div class="in">
93
+ ${await Input.Render({
94
+ id: `sign-up-password`,
95
+ type: 'password',
96
+ autocomplete: 'new-password',
97
+ label: html`<i class="fa-solid fa-lock"></i> ${Translate.Render('password')}`,
98
+ containerClass: 'inl section-mp width-mini-box input-container',
99
+ placeholder: true,
100
+ })}
101
+ </div>
102
+ <div class="in">
103
+ ${await Input.Render({
104
+ id: `sign-up-repeat-password`,
105
+ type: 'password',
106
+ autocomplete: 'new-password',
107
+ label: html`<i class="fa-solid fa-lock"></i> ${Translate.Render('repeat')} ${Translate.Render('password')}`,
108
+ containerClass: 'inl section-mp width-mini-box input-container',
109
+ placeholder: true,
110
+ })}
111
+ </div>
112
+ ${options?.bottomRender ? await options.bottomRender() : ``}
113
+ <div class="in">
114
+ ${await BtnIcon.Render({
115
+ class: 'section-mp form-button btn-sign-up',
116
+ label: Translate.Render('sign-up'),
117
+ type: 'submit',
118
+ })}
119
+ </div>
120
+ </form>
121
+ `;
122
+ },
123
+ };
124
+
125
+ export { SignUp };
@@ -1,72 +1,72 @@
1
- import { io } from 'socket.io/client-dist/socket.io.esm.min.js';
2
- import { loggerFactory } from './Logger.js';
3
- import { getWsBasePath, getWsBaseUrl } from '../../services/core/core.service.js';
4
-
5
- const logger = loggerFactory(import.meta);
6
-
7
- const SocketIo = {
8
- Event: {
9
- connect: {},
10
- connect_error: {},
11
- disconnect: {},
12
- },
13
- /** @type {import('socket.io').Socket} */
14
- socket: null,
15
- Emit: function (channel = '', payload = {}) {
16
- try {
17
- this.socket.emit(channel, JSON.stringify(payload));
18
- } catch (error) {
19
- logger.error(error);
20
- }
21
- },
22
- Init: async function (options) {
23
- if (this.socket) this.socket.disconnect();
24
- this.host = getWsBaseUrl({ wsBasePath: '' });
25
- logger.info(`ws host:`, this.host);
26
- const path = getWsBasePath();
27
- const connectOptions = {
28
- path,
29
- // auth: {
30
- // token: '',
31
- // },
32
- // query: {
33
- // 'my-key': 'my-value',
34
- // },
35
- // forceNew: true,
36
- // reconnectionAttempts: 'Infinity',
37
- // timeout: 10000,
38
- transports: ['websocket', 'polling', 'flashsocket'],
39
- };
40
- // logger.error(`connect options:`, JSON.stringify(connectOptions, null, 4));
41
- this.socket = io(this.host, connectOptions);
42
-
43
- this.socket.on('connect', () => {
44
- logger.info(`event: connect | session id: ${this.socket.id}`);
45
- Object.keys(this.Event.connect).map((keyEvent) => this.Event.connect[keyEvent]());
46
- });
47
-
48
- this.socket.on('connect_error', (err) => {
49
- logger.info(`event: connect_error | reason: ${err.message}`);
50
- Object.keys(this.Event.connect_error).map((keyEvent) => this.Event.connect_error[keyEvent](err));
51
- });
52
-
53
- this.socket.on('disconnect', (reason) => {
54
- logger.info(`event: disconnect | reason: ${reason}`);
55
- Object.keys(this.Event.disconnect).map((keyEvent) => this.Event.disconnect[keyEvent](reason));
56
- });
57
-
58
- if (options && 'channels' in options) this.setChannels(options.channels);
59
- },
60
- setChannels: function (channels) {
61
- Object.keys(channels).map((type) => {
62
- logger.info(`load chanel`, type);
63
- this.Event[type] = {};
64
- this.socket.on(type, (...args) => {
65
- // logger.info(`event: ${type} | ${JSON.stringify(args, null, 4)}`);
66
- Object.keys(this.Event[type]).map((keyEvent) => this.Event[type][keyEvent](args));
67
- });
68
- });
69
- },
70
- };
71
-
72
- export { SocketIo };
1
+ import { io } from 'socket.io/client-dist/socket.io.esm.min.js';
2
+ import { loggerFactory } from './Logger.js';
3
+ import { getWsBasePath, getWsBaseUrl } from '../../services/core/core.service.js';
4
+
5
+ const logger = loggerFactory(import.meta);
6
+
7
+ const SocketIo = {
8
+ Event: {
9
+ connect: {},
10
+ connect_error: {},
11
+ disconnect: {},
12
+ },
13
+ /** @type {import('socket.io').Socket} */
14
+ socket: null,
15
+ Emit: function (channel = '', payload = {}) {
16
+ try {
17
+ this.socket.emit(channel, JSON.stringify(payload));
18
+ } catch (error) {
19
+ logger.error(error);
20
+ }
21
+ },
22
+ Init: async function (options) {
23
+ if (this.socket) this.socket.disconnect();
24
+ this.host = getWsBaseUrl({ wsBasePath: '' });
25
+ logger.info(`ws host:`, this.host);
26
+ const path = getWsBasePath();
27
+ const connectOptions = {
28
+ path,
29
+ // auth: {
30
+ // token: '',
31
+ // },
32
+ // query: {
33
+ // 'my-key': 'my-value',
34
+ // },
35
+ // forceNew: true,
36
+ // reconnectionAttempts: 'Infinity',
37
+ // timeout: 10000,
38
+ transports: ['websocket', 'polling', 'flashsocket'],
39
+ };
40
+ // logger.error(`connect options:`, JSON.stringify(connectOptions, null, 4));
41
+ this.socket = io(this.host, connectOptions);
42
+
43
+ this.socket.on('connect', () => {
44
+ logger.info(`event: connect | session id: ${this.socket.id}`);
45
+ Object.keys(this.Event.connect).map((keyEvent) => this.Event.connect[keyEvent]());
46
+ });
47
+
48
+ this.socket.on('connect_error', (err) => {
49
+ logger.info(`event: connect_error | reason: ${err.message}`);
50
+ Object.keys(this.Event.connect_error).map((keyEvent) => this.Event.connect_error[keyEvent](err));
51
+ });
52
+
53
+ this.socket.on('disconnect', (reason) => {
54
+ logger.info(`event: disconnect | reason: ${reason}`);
55
+ Object.keys(this.Event.disconnect).map((keyEvent) => this.Event.disconnect[keyEvent](reason));
56
+ });
57
+
58
+ if (options && 'channels' in options) this.setChannels(options.channels);
59
+ },
60
+ setChannels: function (channels) {
61
+ Object.keys(channels).map((type) => {
62
+ logger.info(`load chanel`, type);
63
+ this.Event[type] = {};
64
+ this.socket.on(type, (...args) => {
65
+ // logger.info(`event: ${type} | ${JSON.stringify(args, null, 4)}`);
66
+ Object.keys(this.Event[type]).map((keyEvent) => this.Event[type][keyEvent](args));
67
+ });
68
+ });
69
+ },
70
+ };
71
+
72
+ export { SocketIo };