cyberia 3.1.3 → 3.2.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +0 -2
- package/.github/workflows/engine-cyberia.cd.yml +10 -8
- package/.github/workflows/engine-cyberia.ci.yml +12 -29
- package/.github/workflows/ghpkg.ci.yml +4 -4
- package/.github/workflows/npmpkg.ci.yml +28 -11
- package/.github/workflows/publish.ci.yml +21 -2
- package/.github/workflows/pwa-microservices-template-page.cd.yml +4 -5
- package/.github/workflows/pwa-microservices-template-test.ci.yml +3 -3
- package/.github/workflows/release.cd.yml +14 -10
- package/CHANGELOG.md +783 -1
- package/CLI-HELP.md +95 -18
- package/Dockerfile +0 -2
- package/README.md +290 -220
- package/bin/build.js +24 -7
- package/bin/cyberia.js +2838 -252
- package/bin/deploy.js +747 -125
- package/bin/file.js +9 -0
- package/bin/index.js +2838 -252
- package/bin/vs.js +1 -1
- package/conf.js +99 -65
- package/deployment.yaml +18 -164
- package/hardhat/hardhat.config.js +13 -13
- package/hardhat/ignition/modules/ObjectLayerToken.js +1 -1
- package/hardhat/package-lock.json +2559 -5864
- package/hardhat/package.json +14 -23
- package/hardhat/scripts/deployObjectLayerToken.js +1 -1
- package/hardhat/test/ObjectLayerToken.js +4 -2
- package/hardhat/types/ethers-contracts/ObjectLayerToken.ts +690 -0
- package/hardhat/types/ethers-contracts/common.ts +92 -0
- package/hardhat/types/ethers-contracts/factories/ObjectLayerToken__factory.ts +1055 -0
- package/hardhat/types/ethers-contracts/factories/index.ts +4 -0
- package/hardhat/types/ethers-contracts/hardhat.d.ts +47 -0
- package/hardhat/types/ethers-contracts/index.ts +6 -0
- package/jsconfig.json +1 -1
- package/manifests/cronjobs/dd-cron/dd-cron-backup.yaml +6 -5
- package/manifests/cronjobs/dd-cron/dd-cron-dns.yaml +6 -5
- package/manifests/deployment/dd-cyberia-development/deployment.yaml +18 -164
- package/manifests/deployment/dd-cyberia-development/proxy.yaml +7 -79
- package/manifests/deployment/dd-default-development/deployment.yaml +2 -6
- package/manifests/deployment/dd-test-development/deployment.yaml +112 -28
- package/manifests/deployment/dd-test-development/proxy.yaml +46 -1
- package/manifests/deployment/playwright/deployment.yaml +1 -1
- package/nodemon.json +1 -1
- package/package.json +39 -24
- package/proxy.yaml +7 -79
- package/scripts/k3s-node-setup.sh +2 -2
- package/scripts/nat-iptables.sh +103 -18
- package/scripts/rhel-grpc-setup.sh +56 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.controller.js +58 -14
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.model.js +23 -14
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.router.js +5 -0
- package/src/api/atlas-sprite-sheet/atlas-sprite-sheet.service.js +148 -20
- package/src/api/core/core.controller.js +10 -10
- package/src/api/core/core.service.js +10 -10
- package/src/api/crypto/crypto.controller.js +8 -8
- package/src/api/crypto/crypto.service.js +8 -8
- package/src/api/cyberia-action/cyberia-action.controller.js +74 -0
- package/src/api/cyberia-action/cyberia-action.model.js +87 -0
- package/src/api/cyberia-action/cyberia-action.router.js +27 -0
- package/src/api/cyberia-action/cyberia-action.service.js +42 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.controller.js +93 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.model.js +36 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.router.js +29 -0
- package/src/api/cyberia-dialogue/cyberia-dialogue.service.js +51 -0
- package/src/api/cyberia-entity/cyberia-entity.controller.js +74 -0
- package/src/api/cyberia-entity/cyberia-entity.model.js +24 -0
- package/src/api/cyberia-entity/cyberia-entity.router.js +27 -0
- package/src/api/cyberia-entity/cyberia-entity.service.js +42 -0
- package/src/api/cyberia-instance/cyberia-fallback-world.js +178 -0
- package/src/api/cyberia-instance/cyberia-instance.controller.js +92 -0
- package/src/api/cyberia-instance/cyberia-instance.model.js +87 -0
- package/src/api/cyberia-instance/cyberia-instance.router.js +63 -0
- package/src/api/cyberia-instance/cyberia-instance.service.js +156 -0
- package/src/api/cyberia-instance/cyberia-portal-connector.js +260 -0
- package/src/api/cyberia-instance/cyberia-world-generator.js +505 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.controller.js +74 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.defaults.js +574 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.model.js +231 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.router.js +27 -0
- package/src/api/cyberia-instance-conf/cyberia-instance-conf.service.js +46 -0
- package/src/api/cyberia-map/cyberia-map.controller.js +79 -0
- package/src/api/cyberia-map/cyberia-map.model.js +30 -0
- package/src/api/cyberia-map/cyberia-map.router.js +40 -0
- package/src/api/cyberia-map/cyberia-map.service.js +74 -0
- package/src/api/cyberia-quest/cyberia-quest.controller.js +74 -0
- package/src/api/cyberia-quest/cyberia-quest.model.js +67 -0
- package/src/api/cyberia-quest/cyberia-quest.router.js +27 -0
- package/src/api/cyberia-quest/cyberia-quest.service.js +42 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.controller.js +74 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.model.js +49 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.router.js +27 -0
- package/src/api/cyberia-quest-progress/cyberia-quest-progress.service.js +42 -0
- package/src/api/default/default.controller.js +10 -10
- package/src/api/default/default.service.js +10 -10
- package/src/api/document/document.controller.js +12 -12
- package/src/api/document/document.model.js +10 -16
- package/src/api/file/file.controller.js +8 -8
- package/src/api/file/file.model.js +10 -10
- package/src/api/file/file.ref.json +18 -0
- package/src/api/file/file.service.js +36 -36
- package/src/api/instance/instance.controller.js +10 -10
- package/src/api/instance/instance.model.js +4 -10
- package/src/api/instance/instance.service.js +10 -10
- package/src/api/ipfs/ipfs.controller.js +15 -36
- package/src/api/ipfs/ipfs.model.js +47 -47
- package/src/api/ipfs/ipfs.router.js +8 -13
- package/src/api/ipfs/ipfs.service.js +67 -129
- package/src/api/object-layer/object-layer.controller.js +12 -12
- package/src/api/object-layer/object-layer.model.js +4 -17
- package/src/api/object-layer/object-layer.router.js +30 -0
- package/src/api/object-layer/object-layer.service.js +126 -43
- package/src/api/object-layer-render-frames/object-layer-render-frames.controller.js +10 -10
- package/src/api/object-layer-render-frames/object-layer-render-frames.model.js +6 -16
- package/src/api/object-layer-render-frames/object-layer-render-frames.service.js +18 -14
- package/src/api/test/test.controller.js +8 -8
- package/src/api/test/test.service.js +8 -8
- package/src/api/user/guest.service.js +99 -0
- package/src/api/user/user.controller.js +6 -6
- package/src/api/user/user.model.js +8 -13
- package/src/api/user/user.service.js +11 -27
- package/src/cli/cluster.js +68 -21
- package/src/cli/db.js +753 -825
- package/src/cli/deploy.js +215 -125
- package/src/cli/env.js +29 -0
- package/src/cli/fs.js +82 -8
- package/src/cli/image.js +43 -1
- package/src/cli/index.js +74 -3
- package/src/cli/kubectl.js +211 -0
- package/src/cli/release.js +340 -0
- package/src/cli/repository.js +475 -74
- package/src/cli/run.js +582 -43
- package/src/cli/secrets.js +73 -0
- package/src/cli/ssh.js +1 -1
- package/src/cli/static.js +43 -115
- package/src/cli/test.js +3 -3
- package/src/client/Cryptokoyn.index.js +18 -22
- package/src/client/CyberiaPortal.index.js +19 -24
- package/src/client/Default.index.js +21 -34
- package/src/client/Itemledger.index.js +20 -27
- package/src/client/Underpost.index.js +19 -24
- package/src/client/components/core/404.js +4 -4
- package/src/client/components/core/500.js +4 -4
- package/src/client/components/core/Account.js +73 -60
- package/src/client/components/core/AgGrid.js +23 -33
- package/src/client/components/core/Alert.js +12 -13
- package/src/client/components/core/AppStore.js +69 -0
- package/src/client/components/core/Auth.js +35 -37
- package/src/client/components/core/Badge.js +7 -13
- package/src/client/components/core/BtnIcon.js +15 -17
- package/src/client/components/core/CalendarCore.js +43 -64
- package/src/client/components/core/Chat.js +13 -15
- package/src/client/components/core/ClientEvents.js +87 -0
- package/src/client/components/core/ColorPaletteElement.js +309 -0
- package/src/client/components/core/Content.js +17 -14
- package/src/client/components/core/Css.js +15 -71
- package/src/client/components/core/CssCore.js +12 -16
- package/src/client/components/core/D3Chart.js +4 -4
- package/src/client/components/core/Docs.js +64 -91
- package/src/client/components/core/DropDown.js +194 -96
- package/src/client/components/core/EventBus.js +92 -0
- package/src/client/components/core/EventsUI.js +14 -17
- package/src/client/components/core/FileExplorer.js +96 -228
- package/src/client/components/core/FullScreen.js +47 -75
- package/src/client/components/core/Input.js +24 -69
- package/src/client/components/core/Keyboard.js +26 -19
- package/src/client/components/core/KeyboardAvoidance.js +145 -0
- package/src/client/components/core/LoadingAnimation.js +25 -31
- package/src/client/components/core/LogIn.js +43 -43
- package/src/client/components/core/LogOut.js +25 -16
- package/src/client/components/core/Modal.js +462 -179
- package/src/client/components/core/NotificationManager.js +14 -18
- package/src/client/components/core/Panel.js +54 -51
- package/src/client/components/core/PanelForm.js +44 -144
- package/src/client/components/core/Polyhedron.js +110 -214
- package/src/client/components/core/PublicProfile.js +39 -32
- package/src/client/components/core/Recover.js +48 -44
- package/src/client/components/core/Responsive.js +88 -32
- package/src/client/components/core/RichText.js +9 -18
- package/src/client/components/core/Router.js +24 -3
- package/src/client/components/core/SearchBox.js +37 -37
- package/src/client/components/core/SignUp.js +39 -30
- package/src/client/components/core/SocketIo.js +112 -30
- package/src/client/components/core/SocketIoHandler.js +75 -0
- package/src/client/components/core/Stream.js +143 -95
- package/src/client/components/core/ToggleSwitch.js +8 -20
- package/src/client/components/core/ToolTip.js +5 -17
- package/src/client/components/core/Translate.js +56 -59
- package/src/client/components/core/Validator.js +26 -16
- package/src/client/components/core/Wallet.js +15 -26
- package/src/client/components/core/Webhook.js +40 -7
- package/src/client/components/core/Worker.js +163 -27
- package/src/client/components/core/windowGetDimensions.js +7 -7
- package/src/client/components/cryptokoyn/{MenuCryptokoyn.js → AppShellCryptokoyn.js} +59 -59
- package/src/client/components/cryptokoyn/AppStoreCryptokoyn.js +5 -0
- package/src/client/components/cryptokoyn/CssCryptokoyn.js +15 -15
- package/src/client/components/cryptokoyn/LogInCryptokoyn.js +9 -7
- package/src/client/components/cryptokoyn/LogOutCryptokoyn.js +8 -6
- package/src/client/components/cryptokoyn/RouterCryptokoyn.js +37 -0
- package/src/client/components/cryptokoyn/SettingsCryptokoyn.js +4 -4
- package/src/client/components/cryptokoyn/SignUpCryptokoyn.js +6 -4
- package/src/client/components/cryptokoyn/SocketIoCryptokoyn.js +3 -51
- package/src/client/components/cyberia/InstanceEngineCyberia.js +781 -0
- package/src/client/components/cyberia/MapEngineCyberia.js +1836 -2
- package/src/client/components/cyberia/ObjectLayerEngine.js +19 -0
- package/src/client/components/cyberia/ObjectLayerEngineModal.js +1220 -99
- package/src/client/components/cyberia/ObjectLayerEngineViewer.js +252 -316
- package/src/client/components/cyberia-portal/{MenuCyberiaPortal.js → AppShellCyberiaPortal.js} +136 -103
- package/src/client/components/cyberia-portal/AppStoreCyberiaPortal.js +5 -0
- package/src/client/components/cyberia-portal/CommonCyberiaPortal.js +462 -32
- package/src/client/components/cyberia-portal/CssCyberiaPortal.js +15 -15
- package/src/client/components/cyberia-portal/LogInCyberiaPortal.js +9 -7
- package/src/client/components/cyberia-portal/LogOutCyberiaPortal.js +8 -6
- package/src/client/components/cyberia-portal/MainBodyCyberiaPortal.js +4 -4
- package/src/client/components/cyberia-portal/RouterCyberiaPortal.js +60 -0
- package/src/client/components/cyberia-portal/SettingsCyberiaPortal.js +4 -4
- package/src/client/components/cyberia-portal/SignUpCyberiaPortal.js +6 -4
- package/src/client/components/cyberia-portal/SocketIoCyberiaPortal.js +3 -49
- package/src/client/components/cyberia-portal/TranslateCyberiaPortal.js +8 -4
- package/src/client/components/default/{MenuDefault.js → AppShellDefault.js} +91 -91
- package/src/client/components/default/AppStoreDefault.js +5 -0
- package/src/client/components/default/CssDefault.js +12 -12
- package/src/client/components/default/LogInDefault.js +9 -7
- package/src/client/components/default/LogOutDefault.js +8 -6
- package/src/client/components/default/RouterDefault.js +47 -0
- package/src/client/components/default/SettingsDefault.js +4 -4
- package/src/client/components/default/SignUpDefault.js +6 -4
- package/src/client/components/default/SocketIoDefault.js +3 -51
- package/src/client/components/default/TranslateDefault.js +3 -3
- package/src/client/components/itemledger/{MenuItemledger.js → AppShellItemledger.js} +59 -59
- package/src/client/components/itemledger/AppStoreItemledger.js +5 -0
- package/src/client/components/itemledger/CssItemledger.js +15 -15
- package/src/client/components/itemledger/LogInItemledger.js +9 -7
- package/src/client/components/itemledger/LogOutItemledger.js +8 -6
- package/src/client/components/itemledger/RouterItemledger.js +38 -0
- package/src/client/components/itemledger/SettingsItemledger.js +4 -4
- package/src/client/components/itemledger/SignUpItemledger.js +6 -4
- package/src/client/components/itemledger/SocketIoItemledger.js +3 -51
- package/src/client/components/itemledger/TranslateItemledger.js +3 -3
- package/src/client/components/underpost/{MenuUnderpost.js → AppShellUnderpost.js} +92 -92
- package/src/client/components/underpost/AppStoreUnderpost.js +5 -0
- package/src/client/components/underpost/CssUnderpost.js +14 -14
- package/src/client/components/underpost/CyberpunkBloggerUnderpost.js +4 -4
- package/src/client/components/underpost/DocumentSearchProvider.js +1 -1
- package/src/client/components/underpost/LabGalleryUnderpost.js +12 -15
- package/src/client/components/underpost/LogInUnderpost.js +9 -7
- package/src/client/components/underpost/LogOutUnderpost.js +8 -6
- package/src/client/components/underpost/RouterUnderpost.js +45 -0
- package/src/client/components/underpost/SettingsUnderpost.js +4 -4
- package/src/client/components/underpost/SignUpUnderpost.js +6 -4
- package/src/client/components/underpost/SocketIoUnderpost.js +3 -51
- package/src/client/components/underpost/TranslateUnderpost.js +4 -4
- package/src/client/public/cyberia-docs/ACTION-SYSTEM.md +235 -0
- package/src/client/public/cyberia-docs/ARCHITECTURE.md +443 -0
- package/src/client/public/cyberia-docs/CYBERIA-CLI.md +417 -0
- package/src/client/public/cyberia-docs/CYBERIA-CLIENT.md +313 -0
- package/src/client/public/cyberia-docs/CYBERIA-SERVER.md +260 -0
- package/src/client/public/cyberia-docs/ENTITY-PROFILE.md +241 -0
- package/src/client/public/cyberia-docs/HARDHAT-MODULE.md +300 -0
- package/src/client/public/cyberia-docs/OFF-CHAIN-ECONOMY.md +279 -0
- package/src/client/public/cyberia-docs/QUEST-SYSTEM.md +206 -0
- package/src/client/public/cyberia-docs/ROADMAP.md +240 -0
- package/src/client/public/cyberia-docs/WHITE-PAPER.md +732 -0
- package/src/client/services/atlas-sprite-sheet/atlas-sprite-sheet.service.js +14 -20
- package/src/client/services/core/core.service.js +35 -55
- package/src/client/services/crypto/crypto.service.js +8 -13
- package/src/client/services/cyberia-action/cyberia-action.service.js +99 -0
- package/src/client/services/cyberia-dialogue/cyberia-dialogue.service.js +99 -0
- package/src/client/services/cyberia-entity/cyberia-entity.management.js +57 -0
- package/src/client/services/cyberia-entity/cyberia-entity.service.js +99 -0
- package/src/client/services/cyberia-instance/cyberia-instance.management.js +194 -0
- package/src/client/services/cyberia-instance/cyberia-instance.service.js +116 -0
- package/src/client/services/cyberia-instance-conf/cyberia-instance-conf.service.js +99 -0
- package/src/client/services/cyberia-map/cyberia-map.management.js +193 -0
- package/src/client/services/cyberia-map/cyberia-map.service.js +120 -0
- package/src/client/services/cyberia-quest/cyberia-quest.service.js +99 -0
- package/src/client/services/cyberia-quest-progress/cyberia-quest-progress.service.js +99 -0
- package/src/client/services/default/default.management.js +159 -267
- package/src/client/services/default/default.service.js +10 -16
- package/src/client/services/document/document.service.js +14 -19
- package/src/client/services/file/file.service.js +8 -13
- package/src/client/services/instance/instance.management.js +6 -6
- package/src/client/services/instance/instance.service.js +10 -15
- package/src/client/services/ipfs/ipfs.service.js +14 -40
- package/src/client/services/object-layer/object-layer.management.js +14 -14
- package/src/client/services/object-layer/object-layer.service.js +39 -24
- package/src/client/services/object-layer-render-frames/object-layer-render-frames.service.js +10 -16
- package/src/client/services/test/test.service.js +8 -13
- package/src/client/services/user/guest.service.js +86 -0
- package/src/client/services/user/user.management.js +6 -6
- package/src/client/services/user/user.service.js +14 -20
- package/src/client/ssr/body/404.js +3 -3
- package/src/client/ssr/body/500.js +3 -3
- package/src/client/ssr/body/CacheControl.js +5 -2
- package/src/client/ssr/body/DefaultSplashScreen.js +19 -12
- package/src/client/ssr/body/UnderpostDefaultSplashScreen.js +13 -6
- package/src/client/ssr/head/PwaItemledger.js +197 -60
- package/src/client/ssr/mailer/DefaultRecoverEmail.js +19 -20
- package/src/client/ssr/mailer/DefaultVerifyEmail.js +15 -16
- package/src/client/ssr/offline/Maintenance.js +12 -11
- package/src/client/ssr/offline/NoNetworkConnection.js +3 -3
- package/src/client/ssr/pages/CyberiaServerMetrics.js +1 -1
- package/src/client/ssr/pages/Test.js +2 -2
- package/src/client/sw/core.sw.js +212 -0
- package/src/grpc/cyberia/grpc-server.js +642 -0
- package/src/index.js +24 -1
- package/src/runtime/cyberia-client/Dockerfile +80 -0
- package/src/runtime/cyberia-server/Dockerfile +37 -0
- package/src/runtime/express/Dockerfile +5 -1
- package/src/runtime/express/Express.js +18 -1
- package/src/runtime/lampp/Dockerfile +17 -5
- package/src/runtime/lampp/Lampp.js +27 -4
- package/src/runtime/wp/Dockerfile +62 -0
- package/src/runtime/wp/Wp.js +639 -0
- package/src/server/atlas-sprite-sheet-generator.js +4 -2
- package/src/server/auth.js +24 -1
- package/src/server/backup.js +37 -9
- package/src/server/client-build-docs.js +52 -46
- package/src/server/client-build.js +356 -82
- package/src/server/client-formatted.js +140 -57
- package/src/server/conf.js +29 -13
- package/src/server/cron.js +25 -23
- package/src/server/data-query.js +32 -20
- package/src/server/dns.js +24 -1
- package/src/server/ipfs-client.js +253 -89
- package/src/server/object-layer.js +150 -114
- package/src/server/peer.js +8 -0
- package/src/server/process.js +13 -27
- package/src/server/runtime.js +25 -1
- package/src/server/semantic-layer-generator-floor.js +319 -0
- package/src/server/semantic-layer-generator-resource.js +259 -0
- package/src/server/semantic-layer-generator-skin.js +1164 -0
- package/src/server/semantic-layer-generator.js +211 -542
- package/src/server/shape-generator.js +108 -0
- package/src/server/start.js +19 -5
- package/src/server/valkey.js +141 -235
- package/src/ws/IoInterface.js +1 -10
- package/src/ws/IoServer.js +14 -33
- package/src/ws/core/channels/core.ws.chat.js +65 -20
- package/src/ws/core/channels/core.ws.mailer.js +113 -32
- package/src/ws/core/channels/core.ws.stream.js +90 -31
- package/src/ws/core/core.ws.connection.js +12 -33
- package/src/ws/core/core.ws.emit.js +10 -26
- package/src/ws/core/core.ws.server.js +25 -58
- package/src/ws/default/channels/default.ws.main.js +53 -12
- package/src/ws/default/default.ws.connection.js +26 -13
- package/src/ws/default/default.ws.server.js +30 -12
- package/tsconfig.docs.json +15 -0
- package/typedoc.dd-cyberia.json +29 -0
- package/typedoc.json +29 -0
- package/WHITE-PAPER.md +0 -1540
- package/hardhat/README.md +0 -531
- package/hardhat/WHITE-PAPER.md +0 -1540
- package/jsdoc.dd-cyberia.json +0 -59
- package/jsdoc.json +0 -59
- package/src/api/object-layer/README.md +0 -347
- package/src/client/components/core/ColorPalette.js +0 -5267
- package/src/client/components/core/JoyStick.js +0 -80
- package/src/client/components/cryptokoyn/CommonCryptokoyn.js +0 -29
- package/src/client/components/cryptokoyn/ElementsCryptokoyn.js +0 -38
- package/src/client/components/cryptokoyn/RoutesCryptokoyn.js +0 -39
- package/src/client/components/cyberia-portal/ElementsCyberiaPortal.js +0 -38
- package/src/client/components/cyberia-portal/RoutesCyberiaPortal.js +0 -58
- package/src/client/components/cyberia-portal/ServerCyberiaPortal.js +0 -136
- package/src/client/components/default/ElementsDefault.js +0 -38
- package/src/client/components/default/RoutesDefault.js +0 -49
- package/src/client/components/itemledger/CommonItemledger.js +0 -29
- package/src/client/components/itemledger/ElementsItemledger.js +0 -38
- package/src/client/components/itemledger/RoutesItemledger.js +0 -40
- package/src/client/components/underpost/CommonUnderpost.js +0 -29
- package/src/client/components/underpost/ElementsUnderpost.js +0 -38
- package/src/client/components/underpost/RoutesUnderpost.js +0 -47
- package/src/client/sw/default.sw.js +0 -127
- package/src/client/sw/template.sw.js +0 -84
- package/src/ws/core/management/core.ws.chat.js +0 -8
- package/src/ws/core/management/core.ws.mailer.js +0 -16
- package/src/ws/core/management/core.ws.stream.js +0 -8
- package/src/ws/default/management/default.ws.main.js +0 -8
|
@@ -1,120 +1,174 @@
|
|
|
1
|
+
import { Badge } from './Badge.js';
|
|
1
2
|
import { getId, newInstance } from './CommonJs.js';
|
|
3
|
+
import { darkTheme, ThemeEvents } from './Css.js';
|
|
2
4
|
import { Input } from './Input.js';
|
|
3
5
|
import { ToggleSwitch } from './ToggleSwitch.js';
|
|
4
6
|
import { Translate } from './Translate.js';
|
|
5
7
|
import { s, htmls } from './VanillaJs.js';
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
this.Tokens[id] = {
|
|
8
|
+
class DropDown {
|
|
9
|
+
static Tokens = {};
|
|
10
|
+
static async instance(options) {
|
|
11
|
+
const id = options.id ? options.id : getId(DropDown.Tokens, 'dropdown-');
|
|
12
|
+
DropDown.Tokens[id] = {
|
|
12
13
|
onClickEvents: {},
|
|
13
14
|
lastSelectValue: undefined,
|
|
14
15
|
oncheckvalues: {},
|
|
15
16
|
originData: options.data ? newInstance(options.data) : [],
|
|
16
17
|
};
|
|
17
|
-
|
|
18
|
+
const _renderSelectedBadges = async () => {
|
|
19
|
+
if (options.type !== 'checkbox') return;
|
|
20
|
+
const container = s(`.dropdown-current-${id}`);
|
|
21
|
+
if (!container) return;
|
|
22
|
+
const selected = Object.entries(DropDown.Tokens[id].oncheckvalues);
|
|
23
|
+
if (selected.length === 0) {
|
|
24
|
+
htmls(`.dropdown-current-${id}`, '');
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
let badgesHtml = '';
|
|
28
|
+
for (const [key, val] of selected) {
|
|
29
|
+
badgesHtml += html`<span class="inl" style="display:inline-flex;align-items:center;margin:2px;">
|
|
30
|
+
${await Badge.instance({
|
|
31
|
+
text: html`<i class="fa-solid fa-tag" style="margin-right:3px;font-size:9px;"></i>${val.display}`,
|
|
32
|
+
style: {
|
|
33
|
+
background: darkTheme ? '#335' : '#cde',
|
|
34
|
+
color: darkTheme ? '#adf' : '#246',
|
|
35
|
+
'border-radius': '4px',
|
|
36
|
+
'font-size': '11px',
|
|
37
|
+
height: 'auto',
|
|
38
|
+
'min-width': 'auto',
|
|
39
|
+
},
|
|
40
|
+
})}
|
|
41
|
+
<span
|
|
42
|
+
class="dd-badge-del-${id}"
|
|
43
|
+
data-key="${key}"
|
|
44
|
+
style="cursor:pointer;padding:0 4px;font-size:14px;color:${darkTheme ? '#f88' : '#a00'};line-height:1;"
|
|
45
|
+
>×</span
|
|
46
|
+
>
|
|
47
|
+
</span>`;
|
|
48
|
+
}
|
|
49
|
+
htmls(`.dropdown-current-${id}`, badgesHtml);
|
|
50
|
+
container.querySelectorAll(`.dd-badge-del-${id}`).forEach((btn) => {
|
|
51
|
+
btn.onclick = async (e) => {
|
|
52
|
+
e.stopPropagation();
|
|
53
|
+
const key = btn.dataset.key;
|
|
54
|
+
delete DropDown.Tokens[id].oncheckvalues[key];
|
|
55
|
+
const dataItem = options.data.find((d) => d.value.trim().replaceAll(' ', '-') === key);
|
|
56
|
+
if (dataItem) dataItem.checked = false;
|
|
57
|
+
if (ToggleSwitch.Tokens[`checkbox-role-${key}`]) {
|
|
58
|
+
const checkbox = s(`.checkbox-role-${key}-checkbox`);
|
|
59
|
+
if (checkbox && checkbox.checked) ToggleSwitch.Tokens[`checkbox-role-${key}`].click();
|
|
60
|
+
}
|
|
61
|
+
DropDown.Tokens[id].value = Object.values(DropDown.Tokens[id].oncheckvalues).map((v) => v.data);
|
|
62
|
+
s(`.${id}`).value = DropDown.Tokens[id].value;
|
|
63
|
+
await _renderSelectedBadges();
|
|
64
|
+
};
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
DropDown.Tokens[id]._renderSelectedBadges = _renderSelectedBadges;
|
|
18
68
|
options.data.push({
|
|
19
69
|
value: 'reset',
|
|
20
|
-
display: html`<i class="fa-solid fa-broom"></i> ${Translate.
|
|
70
|
+
display: html`<i class="fa-solid fa-broom"></i> ${Translate.instance('clear')}`,
|
|
21
71
|
onClick: () => {
|
|
22
|
-
console.log('DropDown onClick',
|
|
72
|
+
console.log('DropDown onClick', DropDown.value);
|
|
23
73
|
if (options && options.resetOnClick) options.resetOnClick();
|
|
24
|
-
if (options && options.type === 'checkbox')
|
|
25
|
-
|
|
26
|
-
|
|
74
|
+
if (options && options.type === 'checkbox') {
|
|
75
|
+
DropDown.Tokens[id].oncheckvalues = {};
|
|
76
|
+
DropDown.Tokens[id].value = [];
|
|
77
|
+
s(`.${id}`).value = [];
|
|
78
|
+
htmls(`.dropdown-current-${id}`, '');
|
|
79
|
+
if (options.serviceProvider) {
|
|
80
|
+
htmls(`.${id}-render-container`, '');
|
|
81
|
+
} else {
|
|
82
|
+
for (const optionData of options.data) {
|
|
83
|
+
if (optionData.value !== 'reset' && optionData.value !== 'close' && optionData.checked) {
|
|
84
|
+
optionData.checked = false;
|
|
85
|
+
const vd = optionData.value.trim().replaceAll(' ', '-');
|
|
86
|
+
if (ToggleSwitch.Tokens[`checkbox-role-${vd}`]) {
|
|
87
|
+
const checkbox = s(`.checkbox-role-${vd}-checkbox`);
|
|
88
|
+
if (checkbox && checkbox.checked) ToggleSwitch.Tokens[`checkbox-role-${vd}`].click();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
27
92
|
}
|
|
28
|
-
else
|
|
93
|
+
} else DropDown.Tokens[id].value = undefined;
|
|
29
94
|
},
|
|
30
95
|
});
|
|
31
|
-
|
|
32
96
|
if (!(options && options.disableClose))
|
|
33
97
|
options.data.push({
|
|
34
98
|
value: 'close',
|
|
35
|
-
display: html`<i class="fa-solid fa-xmark"></i> ${Translate.
|
|
99
|
+
display: html`<i class="fa-solid fa-xmark"></i> ${Translate.instance('close')}`,
|
|
36
100
|
onClick: function () {
|
|
37
|
-
console.log('DropDown onClick',
|
|
101
|
+
console.log('DropDown onClick', DropDown.value);
|
|
38
102
|
},
|
|
39
103
|
});
|
|
40
|
-
|
|
41
104
|
const switchOptionsPanel = () => {
|
|
42
105
|
if (Array.from(s(`.dropdown-option-${id}`).classList).includes('hide'))
|
|
43
106
|
s(`.dropdown-option-${id}`).classList.remove('hide');
|
|
44
107
|
else s(`.dropdown-option-${id}`).classList.add('hide');
|
|
45
108
|
};
|
|
46
|
-
|
|
47
109
|
const _render = async (data) => {
|
|
48
110
|
let render = '';
|
|
49
111
|
let index = -1;
|
|
50
112
|
for (const optionData of data) {
|
|
51
113
|
index++;
|
|
52
114
|
const i = index;
|
|
53
|
-
const
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
(
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
ToggleSwitch.Tokens[`checkbox-role-${valueDisplay}`]
|
|
72
|
-
|
|
73
|
-
if (optionData.value !== '
|
|
74
|
-
if (
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
this.Tokens[id].onClickEvents[`dropdown-option-${id}-${i}`] = onclick;
|
|
101
|
-
this.Tokens[id].onClickEvents[`dropdown-option-${id}-${valueDisplay}`] = onclick;
|
|
102
|
-
this.Tokens[id].onClickEvents[`dropdown-option-${valueDisplay}`] = onclick;
|
|
103
|
-
|
|
104
|
-
s(`.dropdown-option-${id}-${i}`).onclick = onclick;
|
|
105
|
-
});
|
|
115
|
+
const optionValue = typeof optionData.value === 'string' ? optionData.value : `option-${i}`;
|
|
116
|
+
const valueDisplay = optionValue.trim().replaceAll(' ', '-');
|
|
117
|
+
const isGroup = optionData.kind === 'group' || optionData.nonSelectable === true;
|
|
118
|
+
if (!isGroup) {
|
|
119
|
+
setTimeout(() => {
|
|
120
|
+
const onclick = async (e) => {
|
|
121
|
+
if (options && options.lastSelectClass && s(`.dropdown-option-${DropDown.Tokens[id].lastSelectValue}`)) {
|
|
122
|
+
s(`.dropdown-option-${DropDown.Tokens[id].lastSelectValue}`).classList.remove(options.lastSelectClass);
|
|
123
|
+
}
|
|
124
|
+
DropDown.Tokens[id].lastSelectValue = valueDisplay;
|
|
125
|
+
if (options && options.lastSelectClass && s(`.dropdown-option-${DropDown.Tokens[id].lastSelectValue}`)) {
|
|
126
|
+
s(`.dropdown-option-${DropDown.Tokens[id].lastSelectValue}`).classList.add(options.lastSelectClass);
|
|
127
|
+
}
|
|
128
|
+
if (
|
|
129
|
+
!(options && options.disableClose) &&
|
|
130
|
+
(options.type !== 'checkbox' || optionData.value === 'close' || optionData.value === 'reset')
|
|
131
|
+
)
|
|
132
|
+
s(`.dropdown-option-${id}`).classList.add('hide');
|
|
133
|
+
if (options.type === 'checkbox' && ToggleSwitch.Tokens[`checkbox-role-${valueDisplay}`])
|
|
134
|
+
ToggleSwitch.Tokens[`checkbox-role-${valueDisplay}`].click();
|
|
135
|
+
if (optionData.value !== 'close') {
|
|
136
|
+
if (optionData.value !== 'reset') {
|
|
137
|
+
if (options.type === 'checkbox') {
|
|
138
|
+
_renderSelectedBadges();
|
|
139
|
+
} else {
|
|
140
|
+
htmls(`.dropdown-current-${id}`, optionData.display);
|
|
141
|
+
}
|
|
142
|
+
} else htmls(`.dropdown-current-${id}`, '');
|
|
143
|
+
DropDown.Tokens[id].value =
|
|
144
|
+
options.type === 'checkbox'
|
|
145
|
+
? options.serviceProvider
|
|
146
|
+
? Object.values(DropDown.Tokens[id].oncheckvalues).map((v) => v.data)
|
|
147
|
+
: data.filter((d) => d.checked).map((d) => d.data)
|
|
148
|
+
: optionData.data;
|
|
149
|
+
console.warn('current value dropdown id:' + id, DropDown.Tokens[id].value);
|
|
150
|
+
s(`.${id}`).value = DropDown.Tokens[id].value;
|
|
151
|
+
optionData.onClick(e);
|
|
152
|
+
}
|
|
153
|
+
};
|
|
154
|
+
DropDown.Tokens[id].onClickEvents[`dropdown-option-${id}-${i}`] = onclick;
|
|
155
|
+
DropDown.Tokens[id].onClickEvents[`dropdown-option-${id}-${valueDisplay}`] = onclick;
|
|
156
|
+
DropDown.Tokens[id].onClickEvents[`dropdown-option-${valueDisplay}`] = onclick;
|
|
157
|
+
s(`.dropdown-option-${id}-${i}`).onclick = onclick;
|
|
158
|
+
});
|
|
159
|
+
}
|
|
106
160
|
render += html`
|
|
107
161
|
<div
|
|
108
|
-
class="in dropdown-option
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
? '
|
|
162
|
+
class="in dropdown-option ${isGroup
|
|
163
|
+
? `dropdown-option-group dropdown-option-group-${id}`
|
|
164
|
+
: `dropdown-option-${id}-${i} dropdown-option-${id}-${valueDisplay} dropdown-option-${valueDisplay} ${valueDisplay === 'reset' && options && !(options.resetOption === true) ? 'hide' : ''}`}"
|
|
165
|
+
style="${isGroup
|
|
166
|
+
? 'cursor:default;opacity:.8;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding-top:8px;padding-bottom:6px;'
|
|
113
167
|
: ''}"
|
|
114
168
|
>
|
|
115
|
-
${options.type === 'checkbox' && optionData.value !== 'close' && optionData.value !== 'reset'
|
|
169
|
+
${!isGroup && options.type === 'checkbox' && optionData.value !== 'close' && optionData.value !== 'reset'
|
|
116
170
|
? html`
|
|
117
|
-
${await ToggleSwitch.
|
|
171
|
+
${await ToggleSwitch.instance({
|
|
118
172
|
id: `checkbox-role-${valueDisplay}`,
|
|
119
173
|
type: 'checkbox',
|
|
120
174
|
disabledOnClick: true,
|
|
@@ -126,7 +180,11 @@ const DropDown = {
|
|
|
126
180
|
},
|
|
127
181
|
checked: () => {
|
|
128
182
|
optionData.checked = true;
|
|
129
|
-
DropDown.Tokens[id].oncheckvalues[valueDisplay] = {
|
|
183
|
+
DropDown.Tokens[id].oncheckvalues[valueDisplay] = {
|
|
184
|
+
data: optionData.data,
|
|
185
|
+
display: optionData.display,
|
|
186
|
+
value: optionData.value,
|
|
187
|
+
};
|
|
130
188
|
},
|
|
131
189
|
},
|
|
132
190
|
})}
|
|
@@ -137,7 +195,6 @@ const DropDown = {
|
|
|
137
195
|
}
|
|
138
196
|
return { render, index };
|
|
139
197
|
};
|
|
140
|
-
|
|
141
198
|
setTimeout(() => {
|
|
142
199
|
if (options.type === 'checkbox')
|
|
143
200
|
options.data.map((optionData) => {
|
|
@@ -148,18 +205,23 @@ const DropDown = {
|
|
|
148
205
|
const indexValue = options.data.findIndex((t) => t.value === options.value);
|
|
149
206
|
if (indexValue > -1) setTimeout(() => s(`.dropdown-option-${id}-${indexValue}`).click());
|
|
150
207
|
}
|
|
151
|
-
|
|
152
208
|
s(`.dropdown-label-${id}`).onclick = switchOptionsPanel;
|
|
153
209
|
s(`.dropdown-current-${id}`).onclick = switchOptionsPanel;
|
|
154
210
|
if (options && options.open) switchOptionsPanel();
|
|
155
|
-
|
|
211
|
+
if (options.type === 'checkbox') {
|
|
212
|
+
ThemeEvents[`dropdown-badge-${id}`] = () => _renderSelectedBadges();
|
|
213
|
+
}
|
|
156
214
|
const dropDownSearchHandle = async () => {
|
|
157
215
|
const _data = [];
|
|
158
216
|
if (!s(`.search-box-${id}`)) return;
|
|
159
|
-
|
|
160
217
|
let _value = s(`.search-box-${id}`).value.toLowerCase();
|
|
161
|
-
|
|
162
218
|
for (const objData of options.data) {
|
|
219
|
+
if (
|
|
220
|
+
options.excludeSelected &&
|
|
221
|
+
options.type === 'checkbox' &&
|
|
222
|
+
DropDown.Tokens[id].oncheckvalues[objData.value.trim().replaceAll(' ', '-')]
|
|
223
|
+
)
|
|
224
|
+
continue;
|
|
163
225
|
const objValue = objData.value.toLowerCase();
|
|
164
226
|
if (
|
|
165
227
|
objValue.match(_value) ||
|
|
@@ -171,7 +233,6 @@ const DropDown = {
|
|
|
171
233
|
_data.push(objData);
|
|
172
234
|
}
|
|
173
235
|
}
|
|
174
|
-
|
|
175
236
|
if (_data.length > 0) {
|
|
176
237
|
const { render, index } = await _render(_data);
|
|
177
238
|
htmls(`.${id}-render-container`, render);
|
|
@@ -180,20 +241,58 @@ const DropDown = {
|
|
|
180
241
|
htmls(
|
|
181
242
|
`.${id}-render-container`,
|
|
182
243
|
html` <div class="inl" style="padding: 10px; color: red">
|
|
183
|
-
<i class="fas fa-exclamation-circle"></i> ${Translate.
|
|
244
|
+
<i class="fas fa-exclamation-circle"></i> ${Translate.instance('no-result-found')}
|
|
184
245
|
</div>`,
|
|
185
246
|
);
|
|
186
247
|
}
|
|
187
248
|
};
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
249
|
+
if (options.serviceProvider) {
|
|
250
|
+
let serviceSearchTimeout = null;
|
|
251
|
+
s(`.search-box-${id}`).oninput = () => {
|
|
252
|
+
clearTimeout(serviceSearchTimeout);
|
|
253
|
+
const q = s(`.search-box-${id}`).value.trim();
|
|
254
|
+
if (!q) {
|
|
255
|
+
htmls(`.${id}-render-container`, '');
|
|
256
|
+
return;
|
|
257
|
+
}
|
|
258
|
+
serviceSearchTimeout = setTimeout(async () => {
|
|
259
|
+
try {
|
|
260
|
+
let results = await options.serviceProvider(q);
|
|
261
|
+
if (options.type === 'checkbox') {
|
|
262
|
+
if (options.excludeSelected) {
|
|
263
|
+
const selectedKeys = Object.keys(DropDown.Tokens[id].oncheckvalues);
|
|
264
|
+
results = results.filter((item) => !selectedKeys.includes(item.value.trim().replaceAll(' ', '-')));
|
|
265
|
+
}
|
|
266
|
+
results = results.map((item) => {
|
|
267
|
+
const vd = item.value.trim().replaceAll(' ', '-');
|
|
268
|
+
return { ...item, checked: !!DropDown.Tokens[id].oncheckvalues[vd] };
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
const controlItems = options.data.filter((d) => d.value === 'reset' || d.value === 'close');
|
|
272
|
+
const allData = [...results, ...controlItems];
|
|
273
|
+
if (allData.length > controlItems.length) {
|
|
274
|
+
const { render } = await _render(allData);
|
|
275
|
+
htmls(`.${id}-render-container`, render);
|
|
276
|
+
} else {
|
|
277
|
+
htmls(
|
|
278
|
+
`.${id}-render-container`,
|
|
279
|
+
html` <div class="inl" style="padding: 10px; color: red">
|
|
280
|
+
<i class="fas fa-exclamation-circle"></i> ${Translate.instance('no-result-found')}
|
|
281
|
+
</div>`,
|
|
282
|
+
);
|
|
283
|
+
}
|
|
284
|
+
} catch (e) {
|
|
285
|
+
console.error('DropDown serviceProvider error:', e);
|
|
286
|
+
}
|
|
287
|
+
}, 200);
|
|
288
|
+
};
|
|
289
|
+
} else {
|
|
290
|
+
s(`.search-box-${id}`).oninput = dropDownSearchHandle;
|
|
291
|
+
}
|
|
191
292
|
// Not use onblur generate bug on input toggle
|
|
192
293
|
// s(`.search-box-${id}`).onblur = dropDownSearchHandle;
|
|
193
294
|
});
|
|
194
|
-
|
|
195
295
|
const { render, index } = await _render(options.data);
|
|
196
|
-
|
|
197
296
|
return html`
|
|
198
297
|
<div class="inl dropdown-container ${id} ${options?.containerClass ? options.containerClass : ''}">
|
|
199
298
|
<div class="in dropdown-option dropdown-label-${id} ${options && options.disableSelectLabel ? 'hide' : ''}">
|
|
@@ -206,9 +305,9 @@ const DropDown = {
|
|
|
206
305
|
></div>
|
|
207
306
|
<div class="in dropdown-option-${id} hide">
|
|
208
307
|
<div class="in dropdown-option ${options && options.disableSearchBox ? 'hide' : ''}">
|
|
209
|
-
${await Input.
|
|
308
|
+
${await Input.instance({
|
|
210
309
|
id: `search-box-${id}`,
|
|
211
|
-
label: html`<i class="fa-solid fa-magnifying-glass"></i> ${Translate.
|
|
310
|
+
label: html`<i class="fa-solid fa-magnifying-glass"></i> ${Translate.instance('search')}`,
|
|
212
311
|
containerClass: 'in',
|
|
213
312
|
placeholder: true,
|
|
214
313
|
})}
|
|
@@ -217,7 +316,6 @@ const DropDown = {
|
|
|
217
316
|
</div>
|
|
218
317
|
</div>
|
|
219
318
|
`;
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
|
|
319
|
+
}
|
|
320
|
+
}
|
|
223
321
|
export { DropDown };
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
class EventBus {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.target = new EventTarget();
|
|
4
|
+
this.listeners = new Map();
|
|
5
|
+
this.typeKeys = new Map();
|
|
6
|
+
this.bridges = new Map();
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
ensureBridge(type) {
|
|
10
|
+
if (this.bridges.has(type)) return;
|
|
11
|
+
|
|
12
|
+
const bridge = async (event) => {
|
|
13
|
+
const deferred = event._deferred;
|
|
14
|
+
|
|
15
|
+
try {
|
|
16
|
+
const keys = [...(this.typeKeys.get(type) ?? [])];
|
|
17
|
+
for (const key of keys) {
|
|
18
|
+
const entry = this.listeners.get(key);
|
|
19
|
+
if (!entry) continue;
|
|
20
|
+
|
|
21
|
+
await entry.listener(event.detail, event);
|
|
22
|
+
if (entry.once) this.off(key);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
deferred?.resolve();
|
|
26
|
+
} catch (error) {
|
|
27
|
+
deferred?.reject(error);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
this.bridges.set(type, bridge);
|
|
32
|
+
this.target.addEventListener(type, bridge);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
on(type, listener, options = {}) {
|
|
36
|
+
const key = options.key ?? Symbol(type);
|
|
37
|
+
|
|
38
|
+
this.off(key);
|
|
39
|
+
this.ensureBridge(type);
|
|
40
|
+
|
|
41
|
+
const keys = this.typeKeys.get(type) ?? new Set();
|
|
42
|
+
keys.add(key);
|
|
43
|
+
this.typeKeys.set(type, keys);
|
|
44
|
+
|
|
45
|
+
this.listeners.set(key, {
|
|
46
|
+
type,
|
|
47
|
+
listener,
|
|
48
|
+
once: Boolean(options.once),
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
return () => this.off(key);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
off(key) {
|
|
55
|
+
const entry = this.listeners.get(key);
|
|
56
|
+
if (!entry) return false;
|
|
57
|
+
|
|
58
|
+
this.listeners.delete(key);
|
|
59
|
+
const keys = this.typeKeys.get(entry.type);
|
|
60
|
+
if (keys) {
|
|
61
|
+
keys.delete(key);
|
|
62
|
+
if (keys.size === 0) this.typeKeys.delete(entry.type);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return true;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
has(key) {
|
|
69
|
+
return this.listeners.has(key);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
async emit(type, detail) {
|
|
73
|
+
if (!(this.typeKeys.get(type)?.size > 0)) return;
|
|
74
|
+
|
|
75
|
+
const event = new CustomEvent(type, { detail });
|
|
76
|
+
return await new Promise((resolve, reject) => {
|
|
77
|
+
event._deferred = { resolve, reject };
|
|
78
|
+
this.target.dispatchEvent(event);
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
async emitKey(key, detail) {
|
|
83
|
+
const entry = this.listeners.get(key);
|
|
84
|
+
if (!entry) return;
|
|
85
|
+
|
|
86
|
+
const event = new CustomEvent(entry.type, { detail });
|
|
87
|
+
await entry.listener(detail, event);
|
|
88
|
+
if (entry.once) this.off(key);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export { EventBus };
|
|
@@ -3,11 +3,9 @@ import { loggerFactory } from '../core/Logger.js';
|
|
|
3
3
|
import { cssEffect } from './Css.js';
|
|
4
4
|
import { NotificationManager } from './NotificationManager.js';
|
|
5
5
|
import { s, isActiveElement } from './VanillaJs.js';
|
|
6
|
-
|
|
7
6
|
const logger = loggerFactory(import.meta);
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
on: (id = '', logic = function (e) {}, type = 'onclick', options = {}) => {
|
|
7
|
+
class EventsUI {
|
|
8
|
+
static on = (id = '', logic = function (e) {}, type = 'onclick', options = {}) => {
|
|
11
9
|
const { loadingContainer } = options;
|
|
12
10
|
if (!s(id)) return;
|
|
13
11
|
let complete = true;
|
|
@@ -60,15 +58,15 @@ const EventsUI = {
|
|
|
60
58
|
if (e && e.preventDefault) e.preventDefault();
|
|
61
59
|
logger.warn('in process', id);
|
|
62
60
|
};
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
return await
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return await
|
|
69
|
-
}
|
|
61
|
+
};
|
|
62
|
+
static async onClick(id = '', logic = async function (e) {}, options = { loadingContainer: '' }) {
|
|
63
|
+
return await EventsUI.on(id, logic, 'onclick', options);
|
|
64
|
+
}
|
|
65
|
+
static async onChange(id = '', logic = async function (e) {}, options = { loadingContainer: '' }) {
|
|
66
|
+
return await EventsUI.on(id, logic, 'onchange', options);
|
|
67
|
+
}
|
|
70
68
|
// Shared hover/focus controller extracted from Modal
|
|
71
|
-
HoverFocusController
|
|
69
|
+
static HoverFocusController({ inputSelector, panelSelector, activeElementId, onDismiss } = {}) {
|
|
72
70
|
let hoverPanel = false;
|
|
73
71
|
let hoverInput = false;
|
|
74
72
|
const isActive = () => (activeElementId ? isActiveElement(activeElementId) : false);
|
|
@@ -97,14 +95,14 @@ const EventsUI = {
|
|
|
97
95
|
if (!shouldStay()) onDismiss && onDismiss();
|
|
98
96
|
};
|
|
99
97
|
return { bind, shouldStay, checkDismiss };
|
|
100
|
-
}
|
|
98
|
+
}
|
|
101
99
|
// Generic click-outside binding to dismiss a panel/modal
|
|
102
100
|
// Options:
|
|
103
101
|
// - shouldStay: function -> boolean
|
|
104
102
|
// - onDismiss: function
|
|
105
103
|
// - anchors: array of selectors to treat as inside clicks (e.g., input button, panel container)
|
|
106
104
|
// - graceMs: number of ms after binding to ignore clicks (avoid closing on the same click that opened)
|
|
107
|
-
bindDismissOnDocumentClick
|
|
105
|
+
static bindDismissOnDocumentClick({ shouldStay, onDismiss, anchors = [], graceMs = 200 } = {}) {
|
|
108
106
|
if (typeof document === 'undefined') return () => {};
|
|
109
107
|
const bindAt = Date.now();
|
|
110
108
|
const isInsideAnchors = (target) => {
|
|
@@ -127,7 +125,6 @@ const EventsUI = {
|
|
|
127
125
|
};
|
|
128
126
|
document.addEventListener('click', handler, true);
|
|
129
127
|
return () => document.removeEventListener('click', handler, true);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
|
|
128
|
+
}
|
|
129
|
+
}
|
|
133
130
|
export { EventsUI };
|