@open-core/framework 1.0.5-beta.1 → 1.0.5-beta.2
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/dist/adapters/contracts/IEngineEvents.d.ts +3 -0
- package/dist/adapters/contracts/IEngineEvents.js +7 -0
- package/dist/adapters/contracts/IPlatformContext.d.ts +43 -0
- package/dist/adapters/contracts/IPlatformContext.js +8 -0
- package/dist/adapters/contracts/client/IClientLocalPlayerBridge.d.ts +4 -0
- package/dist/adapters/contracts/client/IClientLocalPlayerBridge.js +2 -0
- package/dist/adapters/contracts/client/IClientLogConsole.d.ts +13 -0
- package/dist/adapters/contracts/client/IClientLogConsole.js +2 -0
- package/dist/adapters/contracts/client/IClientPlatformBridge.d.ts +195 -0
- package/dist/adapters/contracts/client/IClientPlatformBridge.js +282 -0
- package/dist/adapters/contracts/client/IClientRuntimeBridge.d.ts +18 -0
- package/dist/adapters/contracts/client/IClientRuntimeBridge.js +14 -0
- package/dist/adapters/contracts/client/IGtaPedAppearanceBridge.d.ts +26 -0
- package/dist/adapters/contracts/client/IGtaPedAppearanceBridge.js +2 -0
- package/dist/adapters/contracts/client/index.d.ts +7 -0
- package/dist/adapters/contracts/client/index.js +7 -0
- package/dist/adapters/contracts/client/spawn/IClientSpawnBridge.d.ts +7 -0
- package/dist/adapters/contracts/client/spawn/IClientSpawnBridge.js +2 -0
- package/dist/adapters/contracts/client/spawn/index.d.ts +2 -0
- package/dist/adapters/contracts/client/spawn/index.js +2 -0
- package/dist/adapters/contracts/client/spawn/types.d.ts +14 -0
- package/dist/adapters/contracts/client/ui/IClientBlipBridge.d.ts +25 -0
- package/dist/adapters/contracts/client/ui/IClientBlipBridge.js +2 -0
- package/dist/adapters/contracts/client/ui/IClientMarkerBridge.d.ts +31 -0
- package/dist/adapters/contracts/client/ui/IClientMarkerBridge.js +2 -0
- package/dist/adapters/contracts/client/ui/IClientNotificationBridge.d.ts +21 -0
- package/dist/adapters/contracts/client/ui/IClientNotificationBridge.js +2 -0
- package/dist/adapters/contracts/client/ui/index.d.ts +4 -0
- package/dist/adapters/contracts/client/ui/index.js +4 -0
- package/dist/adapters/contracts/client/ui/webview/IClientWebViewBridge.d.ts +13 -0
- package/dist/adapters/contracts/client/ui/webview/IClientWebViewBridge.js +2 -0
- package/dist/adapters/contracts/client/ui/webview/index.d.ts +2 -0
- package/dist/adapters/contracts/client/ui/webview/index.js +2 -0
- package/dist/adapters/contracts/client/ui/webview/types.d.ts +25 -0
- package/dist/adapters/contracts/client/ui/webview/types.js +0 -0
- package/dist/adapters/contracts/index.d.ts +4 -2
- package/dist/adapters/contracts/index.js +4 -3
- package/dist/adapters/contracts/runtime/index.d.ts +1 -0
- package/dist/adapters/contracts/runtime/index.js +1 -0
- package/dist/adapters/contracts/runtime/runtime-events.d.ts +9 -0
- package/dist/adapters/contracts/runtime/runtime-events.js +7 -0
- package/dist/adapters/contracts/server/IEntityServer.d.ts +4 -28
- package/dist/adapters/contracts/server/IEntityServer.js +0 -26
- package/dist/adapters/contracts/server/IPlayerServer.d.ts +7 -26
- package/dist/adapters/contracts/server/IPlayerServer.js +0 -26
- package/dist/adapters/contracts/server/index.d.ts +10 -0
- package/dist/adapters/contracts/server/index.js +10 -0
- package/dist/adapters/contracts/server/npc-lifecycle/INpcLifecycleServer.d.ts +5 -0
- package/dist/adapters/contracts/server/npc-lifecycle/INpcLifecycleServer.js +2 -0
- package/dist/adapters/contracts/server/npc-lifecycle/index.d.ts +2 -0
- package/dist/adapters/contracts/server/npc-lifecycle/index.js +2 -0
- package/dist/adapters/contracts/server/npc-lifecycle/types.d.ts +17 -0
- package/dist/adapters/contracts/server/npc-lifecycle/types.js +0 -0
- package/dist/adapters/contracts/server/player-appearance/IPlayerAppearanceLifecycleServer.d.ts +11 -0
- package/dist/adapters/contracts/server/player-appearance/IPlayerAppearanceLifecycleServer.js +2 -0
- package/dist/adapters/contracts/server/player-appearance/index.d.ts +1 -0
- package/dist/adapters/contracts/server/player-appearance/index.js +1 -0
- package/dist/adapters/contracts/server/player-lifecycle/IPlayerLifecycleServer.d.ts +6 -0
- package/dist/adapters/contracts/server/player-lifecycle/IPlayerLifecycleServer.js +2 -0
- package/dist/adapters/contracts/server/player-lifecycle/index.d.ts +2 -0
- package/dist/adapters/contracts/server/player-lifecycle/index.js +2 -0
- package/dist/adapters/contracts/server/player-lifecycle/types.d.ts +17 -0
- package/dist/adapters/contracts/server/player-lifecycle/types.js +0 -0
- package/dist/adapters/contracts/server/player-state/IPlayerStateSyncServer.d.ts +6 -0
- package/dist/adapters/contracts/server/player-state/IPlayerStateSyncServer.js +2 -0
- package/dist/adapters/contracts/server/player-state/index.d.ts +1 -0
- package/dist/adapters/contracts/server/player-state/index.js +1 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/IVehicleLifecycleServer.d.ts +5 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/IVehicleLifecycleServer.js +2 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/index.d.ts +2 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/index.js +2 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/types.d.ts +16 -0
- package/dist/adapters/contracts/server/vehicle-lifecycle/types.js +0 -0
- package/dist/adapters/contracts/transport/index.d.ts +4 -0
- package/dist/adapters/contracts/transport/index.js +4 -0
- package/dist/adapters/index.d.ts +3 -14
- package/dist/adapters/index.js +3 -20
- package/dist/adapters/node/node-capabilities.d.ts +11 -11
- package/dist/adapters/node/node-capabilities.js +15 -27
- package/dist/adapters/node/node-engine-events.d.ts +1 -1
- package/dist/adapters/node/node-engine-events.js +2 -1
- package/dist/adapters/node/node-entity-server.d.ts +2 -2
- package/dist/adapters/node/node-entity-server.js +2 -2
- package/dist/adapters/node/node-ped-appearance-client.d.ts +2 -2
- package/dist/adapters/node/node-ped-appearance-client.js +2 -2
- package/dist/adapters/node/node-platform.js +4 -4
- package/dist/adapters/node/node-player-server.d.ts +3 -2
- package/dist/adapters/node/node-player-server.js +8 -2
- package/dist/adapters/register-capabilities.d.ts +1 -1
- package/dist/adapters/register-capabilities.js +1 -3
- package/dist/adapters/register-client-capabilities.d.ts +3 -2
- package/dist/adapters/register-client-capabilities.js +16 -41
- package/dist/contracts/client.d.ts +5 -0
- package/dist/contracts/client.js +5 -0
- package/dist/contracts/server.d.ts +19 -0
- package/dist/contracts/server.js +19 -0
- package/dist/contracts.d.ts +4 -0
- package/dist/contracts.js +4 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +1 -1
- package/dist/kernel/logger/client-log-console.d.ts +4 -0
- package/dist/kernel/logger/client-log-console.js +43 -0
- package/dist/kernel/logger/core-logger.d.ts +3 -1
- package/dist/kernel/logger/core-logger.js +4 -2
- package/dist/kernel/logger/index.d.ts +2 -0
- package/dist/kernel/logger/index.js +1 -0
- package/dist/kernel/logger/transports/dev-transport.factory.js +1 -1
- package/dist/kernel/logger/transports/simple-console.transport.js +13 -8
- package/dist/kernel-public.d.ts +1 -0
- package/dist/kernel-public.js +1 -0
- package/dist/runtime/client/adapter/client-adapter.d.ts +25 -0
- package/dist/runtime/client/adapter/client-adapter.js +11 -0
- package/dist/runtime/client/adapter/index.d.ts +15 -0
- package/dist/runtime/client/adapter/index.js +15 -0
- package/dist/runtime/client/adapter/local-player-bridge.d.ts +1 -0
- package/dist/runtime/client/adapter/local-player-bridge.js +1 -0
- package/dist/runtime/client/adapter/node-blip-bridge.d.ts +9 -0
- package/dist/runtime/client/adapter/node-blip-bridge.js +34 -0
- package/dist/runtime/client/adapter/node-client-adapter.d.ts +5 -0
- package/dist/runtime/client/adapter/node-client-adapter.js +50 -0
- package/dist/runtime/client/adapter/node-local-player-bridge.d.ts +8 -0
- package/dist/{adapters/fivem/fivem-hasher.js → runtime/client/adapter/node-local-player-bridge.js} +7 -9
- package/dist/runtime/client/adapter/node-log-console.d.ts +11 -0
- package/dist/runtime/client/adapter/node-log-console.js +48 -0
- package/dist/runtime/client/adapter/node-marker-bridge.d.ts +10 -0
- package/dist/runtime/client/adapter/node-marker-bridge.js +35 -0
- package/dist/runtime/client/adapter/node-notification-bridge.d.ts +5 -0
- package/dist/runtime/client/adapter/node-notification-bridge.js +16 -0
- package/dist/runtime/client/adapter/node-platform-bridge.d.ts +3 -0
- package/dist/{adapters/fivem/fivem-tick.js → runtime/client/adapter/node-platform-bridge.js} +5 -10
- package/dist/runtime/client/adapter/node-runtime-bridge.d.ts +24 -0
- package/dist/runtime/client/adapter/node-runtime-bridge.js +58 -0
- package/dist/runtime/client/adapter/node-spawn-bridge.d.ts +8 -0
- package/dist/runtime/client/adapter/node-spawn-bridge.js +18 -0
- package/dist/runtime/client/adapter/node-webview-bridge.d.ts +15 -0
- package/dist/runtime/client/adapter/node-webview-bridge.js +43 -0
- package/dist/runtime/client/adapter/platform-bridge.d.ts +1 -0
- package/dist/runtime/client/adapter/platform-bridge.js +1 -0
- package/dist/runtime/client/adapter/registry.d.ts +9 -0
- package/dist/runtime/client/adapter/registry.js +85 -0
- package/dist/runtime/client/adapter/runtime-bridge.d.ts +1 -0
- package/dist/runtime/client/adapter/runtime-bridge.js +1 -0
- package/dist/runtime/client/api.d.ts +2 -1
- package/dist/runtime/client/api.js +2 -1
- package/dist/runtime/client/client-bootstrap.js +51 -44
- package/dist/runtime/client/client-core.d.ts +2 -0
- package/dist/runtime/client/client-core.js +9 -0
- package/dist/runtime/client/client-runtime.d.ts +3 -0
- package/dist/runtime/client/client-runtime.js +3 -0
- package/dist/runtime/client/controllers/appearance.controller.d.ts +3 -1
- package/dist/runtime/client/controllers/appearance.controller.js +14 -4
- package/dist/runtime/client/controllers/spawner.controller.js +2 -0
- package/dist/runtime/client/decorators/controller.js +2 -10
- package/dist/runtime/client/decorators/onView.d.ts +3 -3
- package/dist/runtime/client/decorators/onView.js +3 -3
- package/dist/runtime/client/index.d.ts +1 -0
- package/dist/runtime/client/index.js +1 -0
- package/dist/runtime/client/library/create-client-library.js +9 -1
- package/dist/runtime/client/services/appearance.service.d.ts +2 -2
- package/dist/runtime/client/services/appearance.service.js +7 -4
- package/dist/runtime/client/services/blip.service.d.ts +6 -93
- package/dist/runtime/client/services/blip.service.js +58 -153
- package/dist/runtime/client/services/camera-effects.registry.d.ts +3 -0
- package/dist/runtime/client/services/camera-effects.registry.js +20 -7
- package/dist/runtime/client/services/camera.d.ts +3 -83
- package/dist/runtime/client/services/camera.js +37 -93
- package/dist/runtime/client/services/cinematic.d.ts +5 -1
- package/dist/runtime/client/services/cinematic.js +45 -30
- package/dist/runtime/client/services/index.d.ts +1 -0
- package/dist/runtime/client/services/index.js +1 -0
- package/dist/runtime/client/services/marker.service.d.ts +12 -63
- package/dist/runtime/client/services/marker.service.js +62 -97
- package/dist/runtime/client/services/notification.service.d.ts +6 -57
- package/dist/runtime/client/services/notification.service.js +43 -81
- package/dist/runtime/client/services/ped.service.d.ts +3 -130
- package/dist/runtime/client/services/ped.service.js +66 -198
- package/dist/runtime/client/services/progress.service.d.ts +5 -30
- package/dist/runtime/client/services/progress.service.js +73 -99
- package/dist/runtime/client/services/session-bridge.service.d.ts +15 -0
- package/dist/runtime/client/services/session-bridge.service.js +61 -0
- package/dist/runtime/client/services/spawn.service.d.ts +6 -56
- package/dist/runtime/client/services/spawn.service.js +34 -191
- package/dist/runtime/client/services/streaming.service.d.ts +5 -126
- package/dist/runtime/client/services/streaming.service.js +72 -217
- package/dist/runtime/client/services/textui.service.d.ts +5 -45
- package/dist/runtime/client/services/textui.service.js +55 -88
- package/dist/runtime/client/services/vehicle-client.service.d.ts +12 -149
- package/dist/runtime/client/services/vehicle-client.service.js +180 -326
- package/dist/runtime/client/services/vehicle.service.d.ts +3 -109
- package/dist/runtime/client/services/vehicle.service.js +94 -194
- package/dist/runtime/client/system/processors/export.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/export.processor.js +16 -3
- package/dist/runtime/client/system/processors/gameEvent.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/gameEvent.processor.js +16 -3
- package/dist/runtime/client/system/processors/interval.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/interval.processor.js +17 -4
- package/dist/runtime/client/system/processors/key.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/key.processor.js +18 -5
- package/dist/runtime/client/system/processors/localEvent.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/localEvent.processor.js +16 -3
- package/dist/runtime/client/system/processors/netEvent.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/netEvent.processor.js +16 -3
- package/dist/runtime/client/system/processors/onRpc.processor.js +1 -1
- package/dist/runtime/client/system/processors/resourceLifecycle.processor.d.ts +5 -0
- package/dist/runtime/client/system/processors/resourceLifecycle.processor.js +26 -7
- package/dist/runtime/client/system/processors/tick.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/tick.processor.js +16 -3
- package/dist/runtime/client/system/processors/view.processor.d.ts +3 -0
- package/dist/runtime/client/system/processors/view.processor.js +21 -10
- package/dist/runtime/client/system/processors.register.d.ts +1 -0
- package/dist/runtime/client/system/processors.register.js +8 -0
- package/dist/runtime/client/ui-bridge.d.ts +2 -114
- package/dist/runtime/client/ui-bridge.js +2 -194
- package/dist/runtime/client/webview-bridge.d.ts +31 -0
- package/dist/runtime/client/webview-bridge.js +97 -0
- package/dist/runtime/client/webview.service.d.ts +14 -0
- package/dist/runtime/client/webview.service.js +98 -0
- package/dist/runtime/server/adapter/index.d.ts +5 -0
- package/dist/runtime/server/adapter/index.js +5 -0
- package/dist/runtime/server/adapter/node-npc-lifecycle-server.d.ts +12 -0
- package/dist/runtime/server/adapter/node-npc-lifecycle-server.js +52 -0
- package/dist/runtime/server/adapter/node-player-appearance-lifecycle-server.d.ts +22 -0
- package/dist/runtime/server/adapter/node-player-appearance-lifecycle-server.js +94 -0
- package/dist/runtime/server/adapter/node-player-lifecycle-server.d.ts +11 -0
- package/dist/runtime/server/adapter/node-player-lifecycle-server.js +55 -0
- package/dist/runtime/server/adapter/node-player-state-sync-server.d.ts +12 -0
- package/dist/runtime/server/adapter/node-player-state-sync-server.js +49 -0
- package/dist/runtime/server/adapter/node-server-adapter.d.ts +5 -0
- package/dist/runtime/server/adapter/node-server-adapter.js +67 -0
- package/dist/runtime/server/adapter/node-vehicle-lifecycle-server.d.ts +13 -0
- package/dist/runtime/server/adapter/node-vehicle-lifecycle-server.js +57 -0
- package/dist/runtime/server/adapter/player-adapter.d.ts +28 -0
- package/dist/runtime/server/adapter/player-adapter.js +28 -0
- package/dist/runtime/server/adapter/registry.d.ts +26 -0
- package/dist/runtime/server/adapter/registry.js +101 -0
- package/dist/runtime/server/adapter/serialization.d.ts +6 -0
- package/dist/runtime/server/adapter/serialization.js +9 -0
- package/dist/runtime/server/adapter/server-adapter.d.ts +28 -0
- package/dist/runtime/server/adapter/server-adapter.js +14 -0
- package/dist/runtime/server/api.d.ts +2 -1
- package/dist/runtime/server/api.js +2 -1
- package/dist/runtime/server/apis/appearance.api.d.ts +5 -3
- package/dist/runtime/server/apis/appearance.api.js +20 -7
- package/dist/runtime/server/apis/npcs.api.d.ts +3 -4
- package/dist/runtime/server/apis/npcs.api.js +26 -56
- package/dist/runtime/server/apis/vehicle-modification.api.d.ts +3 -1
- package/dist/runtime/server/apis/vehicle-modification.api.js +9 -4
- package/dist/runtime/server/apis/vehicles.api.d.ts +12 -6
- package/dist/runtime/server/apis/vehicles.api.js +48 -36
- package/dist/runtime/server/bootstrap.js +15 -7
- package/dist/runtime/server/controllers/channel.controller.js +2 -1
- package/dist/runtime/server/controllers/command-export.controller.js +1 -1
- package/dist/runtime/server/controllers/player-export.controller.js +5 -4
- package/dist/runtime/server/controllers/session.controller.js +3 -2
- package/dist/runtime/server/controllers/vehicle.controller.d.ts +3 -1
- package/dist/runtime/server/controllers/vehicle.controller.js +10 -5
- package/dist/runtime/server/core.d.ts +2 -0
- package/dist/runtime/server/core.js +9 -1
- package/dist/runtime/server/decorators/onRuntimeEvent.d.ts +2 -1
- package/dist/runtime/server/entities/npc.d.ts +2 -0
- package/dist/runtime/server/entities/npc.js +3 -3
- package/dist/runtime/server/entities/player.d.ts +8 -11
- package/dist/runtime/server/entities/player.js +39 -28
- package/dist/runtime/server/entities/vehicle.js +2 -2
- package/dist/runtime/server/error-handler.js +13 -2
- package/dist/runtime/server/helpers/command-validation.helper.js +1 -1
- package/dist/runtime/server/implementations/local/player.local.d.ts +7 -3
- package/dist/runtime/server/implementations/local/player.local.js +23 -11
- package/dist/runtime/server/implementations/remote/channel.remote.d.ts +2 -1
- package/dist/runtime/server/implementations/remote/channel.remote.js +5 -2
- package/dist/runtime/server/implementations/remote/command.remote.d.ts +3 -1
- package/dist/runtime/server/implementations/remote/command.remote.js +9 -4
- package/dist/runtime/server/implementations/remote/player.remote.d.ts +7 -10
- package/dist/runtime/server/implementations/remote/player.remote.js +24 -29
- package/dist/runtime/server/library/create-server-library.js +17 -2
- package/dist/runtime/server/runtime.d.ts +3 -0
- package/dist/runtime/server/runtime.js +1 -15
- package/dist/runtime/server/services/appearance.service.d.ts +0 -95
- package/dist/runtime/server/services/appearance.service.js +15 -192
- package/dist/runtime/server/services/services.register.js +56 -24
- package/dist/runtime/server/system/processors/netEvent.processor.js +1 -1
- package/dist/runtime/server/system/processors/onRpc.processor.js +1 -1
- package/dist/runtime/server/system/processors/runtimeEvent.processor.d.ts +2 -1
- package/dist/runtime/server/system/processors/runtimeEvent.processor.js +1 -1
- package/dist/runtime/server/types/core-exports.types.d.ts +5 -0
- package/dist/runtime/shared/helpers/process-tuple-schema.d.ts +2 -0
- package/dist/runtime/shared/helpers/process-tuple-schema.js +29 -0
- package/package.json +21 -3
- package/dist/adapters/cfx/cfx-capabilities.d.ts +0 -16
- package/dist/adapters/cfx/cfx-capabilities.js +0 -70
- package/dist/adapters/cfx/cfx-platform.d.ts +0 -2
- package/dist/adapters/cfx/cfx-platform.js +0 -85
- package/dist/adapters/cfx/index.d.ts +0 -3
- package/dist/adapters/cfx/index.js +0 -3
- package/dist/adapters/cfx/runtime-profile.d.ts +0 -3
- package/dist/adapters/cfx/runtime-profile.js +0 -37
- package/dist/adapters/contracts/IPlatformCapabilities.d.ts +0 -79
- package/dist/adapters/contracts/IPlatformCapabilities.js +0 -27
- package/dist/adapters/contracts/client/IPedAppearanceClient.d.ts +0 -206
- package/dist/adapters/contracts/client/IPedAppearanceClient.js +0 -12
- package/dist/adapters/fivem/fivem-capabilities.d.ts +0 -18
- package/dist/adapters/fivem/fivem-capabilities.js +0 -61
- package/dist/adapters/fivem/fivem-engine-events.d.ts +0 -5
- package/dist/adapters/fivem/fivem-engine-events.js +0 -24
- package/dist/adapters/fivem/fivem-entity-server.d.ts +0 -26
- package/dist/adapters/fivem/fivem-entity-server.js +0 -87
- package/dist/adapters/fivem/fivem-exports.d.ts +0 -5
- package/dist/adapters/fivem/fivem-exports.js +0 -9
- package/dist/adapters/fivem/fivem-hasher.d.ts +0 -7
- package/dist/adapters/fivem/fivem-net-transport.d.ts +0 -1
- package/dist/adapters/fivem/fivem-ped-appearance-client.d.ts +0 -34
- package/dist/adapters/fivem/fivem-ped-appearance-client.js +0 -79
- package/dist/adapters/fivem/fivem-ped-appearance-server.d.ts +0 -14
- package/dist/adapters/fivem/fivem-ped-appearance-server.js +0 -22
- package/dist/adapters/fivem/fivem-ped-server.d.ts +0 -9
- package/dist/adapters/fivem/fivem-ped-server.js +0 -30
- package/dist/adapters/fivem/fivem-platform.d.ts +0 -5
- package/dist/adapters/fivem/fivem-platform.js +0 -74
- package/dist/adapters/fivem/fivem-player-server.d.ts +0 -24
- package/dist/adapters/fivem/fivem-player-server.js +0 -83
- package/dist/adapters/fivem/fivem-playerinfo.d.ts +0 -6
- package/dist/adapters/fivem/fivem-playerinfo.js +0 -10
- package/dist/adapters/fivem/fivem-resourceinfo.d.ts +0 -5
- package/dist/adapters/fivem/fivem-resourceinfo.js +0 -24
- package/dist/adapters/fivem/fivem-tick.d.ts +0 -7
- package/dist/adapters/fivem/fivem-vehicle-server.d.ts +0 -15
- package/dist/adapters/fivem/fivem-vehicle-server.js +0 -44
- package/dist/adapters/fivem/index.d.ts +0 -14
- package/dist/adapters/fivem/index.js +0 -16
- package/dist/adapters/fivem/transport/adapter.d.ts +0 -8
- package/dist/adapters/fivem/transport/adapter.js +0 -8
- package/dist/adapters/fivem/transport/fivem.events.d.ts +0 -8
- package/dist/adapters/fivem/transport/fivem.events.js +0 -36
- package/dist/adapters/fivem/transport/fivem.rpc.d.ts +0 -28
- package/dist/adapters/fivem/transport/fivem.rpc.js +0 -183
- package/dist/runtime/client/controllers/player-sync.controller.d.ts +0 -11
- package/dist/runtime/client/controllers/player-sync.controller.js +0 -51
- package/dist/runtime/client/player/player.d.ts +0 -262
- package/dist/runtime/client/player/player.js +0 -474
- package/dist/runtime/client/player/player.loader.d.ts +0 -1
- package/dist/runtime/client/player/player.loader.js +0 -18
- package/dist/runtime/server/helpers/process-tuple-schema.d.ts +0 -20
- package/dist/runtime/server/helpers/process-tuple-schema.js +0 -56
- /package/dist/adapters/{fivem/fivem-net-transport.js → contracts/client/spawn/types.js} +0 -0
|
@@ -7,477 +7,331 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
* @remarks
|
|
18
|
-
* - Vehicle creation is server-authoritative (prevents spawning exploits)
|
|
19
|
-
* - Modifications require server validation
|
|
20
|
-
* - Local operations (queries, visual changes) are safe to perform client-side
|
|
21
|
-
*/
|
|
10
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
11
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
12
|
+
};
|
|
13
|
+
import { inject, injectable } from 'tsyringe';
|
|
14
|
+
import { EventsAPI } from '../../../adapters/contracts/transport/events.api';
|
|
15
|
+
import { IClientPlatformBridge } from '../adapter/platform-bridge';
|
|
16
|
+
import { IClientRuntimeBridge } from '../adapter/runtime-bridge';
|
|
22
17
|
let VehicleClientService = class VehicleClientService {
|
|
18
|
+
events;
|
|
19
|
+
platform;
|
|
20
|
+
runtime;
|
|
23
21
|
pendingCreations = new Map();
|
|
22
|
+
pendingDeletes = new Map();
|
|
23
|
+
pendingRepairs = new Map();
|
|
24
|
+
pendingData = new Map();
|
|
25
|
+
pendingPlayerVehicles = null;
|
|
24
26
|
requestIdCounter = 0;
|
|
25
|
-
constructor() {
|
|
27
|
+
constructor(events, platform, runtime) {
|
|
28
|
+
this.events = events;
|
|
29
|
+
this.platform = platform;
|
|
30
|
+
this.runtime = runtime;
|
|
26
31
|
this.registerEventHandlers();
|
|
27
32
|
}
|
|
28
|
-
/**
|
|
29
|
-
* Requests vehicle creation from the server.
|
|
30
|
-
*
|
|
31
|
-
* @param options - Vehicle creation options
|
|
32
|
-
* @returns Promise resolving to spawn result
|
|
33
|
-
*/
|
|
34
33
|
async createVehicle(options) {
|
|
35
34
|
return new Promise((resolve) => {
|
|
36
35
|
const requestId = this.requestIdCounter++;
|
|
37
36
|
this.pendingCreations.set(requestId, resolve);
|
|
38
|
-
|
|
39
|
-
...options,
|
|
40
|
-
_requestId: requestId,
|
|
41
|
-
});
|
|
37
|
+
this.events.emit('opencore:vehicle:create', { ...options, _requestId: requestId });
|
|
42
38
|
setTimeout(() => {
|
|
43
|
-
if (this.pendingCreations.has(requestId))
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
handle: 0,
|
|
48
|
-
success: false,
|
|
49
|
-
error: 'Request timeout',
|
|
50
|
-
});
|
|
51
|
-
}
|
|
39
|
+
if (!this.pendingCreations.has(requestId))
|
|
40
|
+
return;
|
|
41
|
+
this.pendingCreations.delete(requestId);
|
|
42
|
+
resolve({ networkId: 0, handle: 0, success: false, error: 'Request timeout' });
|
|
52
43
|
}, 5000);
|
|
53
44
|
});
|
|
54
45
|
}
|
|
55
|
-
/**
|
|
56
|
-
* Requests vehicle deletion from the server.
|
|
57
|
-
*
|
|
58
|
-
* @param networkId - Network ID of the vehicle
|
|
59
|
-
* @returns Promise resolving to success status
|
|
60
|
-
*/
|
|
61
46
|
async deleteVehicle(networkId) {
|
|
62
47
|
return new Promise((resolve) => {
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
resolve(result.success);
|
|
66
|
-
}
|
|
67
|
-
};
|
|
68
|
-
const eventName = 'opencore:vehicle:deleteResult';
|
|
69
|
-
onNet(eventName, handler);
|
|
70
|
-
emitNet('opencore:vehicle:delete', networkId);
|
|
48
|
+
this.pendingDeletes.set(networkId, resolve);
|
|
49
|
+
this.events.emit('opencore:vehicle:delete', networkId);
|
|
71
50
|
setTimeout(() => {
|
|
72
|
-
|
|
51
|
+
if (!this.pendingDeletes.has(networkId))
|
|
52
|
+
return;
|
|
53
|
+
this.pendingDeletes.delete(networkId);
|
|
73
54
|
resolve(false);
|
|
74
55
|
}, 5000);
|
|
75
56
|
});
|
|
76
57
|
}
|
|
77
|
-
/**
|
|
78
|
-
* Requests vehicle repair from the server.
|
|
79
|
-
*
|
|
80
|
-
* @param networkId - Network ID of the vehicle
|
|
81
|
-
* @returns Promise resolving to success status
|
|
82
|
-
*/
|
|
83
58
|
async repairVehicle(networkId) {
|
|
84
59
|
return new Promise((resolve) => {
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
resolve(result.success);
|
|
88
|
-
}
|
|
89
|
-
};
|
|
90
|
-
const eventName = 'opencore:vehicle:repairResult';
|
|
91
|
-
onNet(eventName, handler);
|
|
92
|
-
emitNet('opencore:vehicle:repair', networkId);
|
|
60
|
+
this.pendingRepairs.set(networkId, resolve);
|
|
61
|
+
this.events.emit('opencore:vehicle:repair', networkId);
|
|
93
62
|
setTimeout(() => {
|
|
94
|
-
|
|
63
|
+
if (!this.pendingRepairs.has(networkId))
|
|
64
|
+
return;
|
|
65
|
+
this.pendingRepairs.delete(networkId);
|
|
95
66
|
resolve(false);
|
|
96
67
|
}, 5000);
|
|
97
68
|
});
|
|
98
69
|
}
|
|
99
|
-
/**
|
|
100
|
-
* Gets the closest vehicle to the player.
|
|
101
|
-
*
|
|
102
|
-
* @param radius - Search radius
|
|
103
|
-
* @returns Vehicle handle or null
|
|
104
|
-
*/
|
|
105
70
|
getClosestVehicle(radius = 10.0) {
|
|
106
|
-
const playerPed =
|
|
107
|
-
|
|
108
|
-
const vehicle = GetClosestVehicle(px, py, pz, radius, 0, 71);
|
|
109
|
-
return vehicle !== 0 ? vehicle : null;
|
|
71
|
+
const playerPed = this.platform.getLocalPlayerPed();
|
|
72
|
+
return this.platform.getClosestVehicle(this.platform.getEntityCoords(playerPed), radius);
|
|
110
73
|
}
|
|
111
|
-
/**
|
|
112
|
-
* Checks if the player is in a vehicle.
|
|
113
|
-
*/
|
|
114
74
|
isPlayerInVehicle() {
|
|
115
|
-
return
|
|
75
|
+
return this.platform.isPedInAnyVehicle(this.platform.getLocalPlayerPed());
|
|
116
76
|
}
|
|
117
|
-
/**
|
|
118
|
-
* Gets the vehicle the player is currently in.
|
|
119
|
-
*
|
|
120
|
-
* @returns Vehicle handle or null
|
|
121
|
-
*/
|
|
122
77
|
getCurrentVehicle() {
|
|
123
|
-
const ped =
|
|
124
|
-
if (!
|
|
78
|
+
const ped = this.platform.getLocalPlayerPed();
|
|
79
|
+
if (!this.platform.isPedInAnyVehicle(ped))
|
|
125
80
|
return null;
|
|
126
|
-
return
|
|
81
|
+
return this.platform.getVehiclePedIsIn(ped, false);
|
|
127
82
|
}
|
|
128
|
-
/**
|
|
129
|
-
* Gets the last vehicle the player was in.
|
|
130
|
-
*
|
|
131
|
-
* @returns Vehicle handle or null
|
|
132
|
-
*/
|
|
133
83
|
getLastVehicle() {
|
|
134
|
-
|
|
135
|
-
return vehicle !== 0 ? vehicle : null;
|
|
84
|
+
return this.platform.getVehiclePedIsIn(this.platform.getLocalPlayerPed(), true);
|
|
136
85
|
}
|
|
137
|
-
/**
|
|
138
|
-
* Checks if player is the driver of their current vehicle.
|
|
139
|
-
*/
|
|
140
86
|
isPlayerDriver() {
|
|
141
87
|
const vehicle = this.getCurrentVehicle();
|
|
142
88
|
if (!vehicle)
|
|
143
89
|
return false;
|
|
144
|
-
return
|
|
90
|
+
return this.platform.getPedInVehicleSeat(vehicle, -1) === this.platform.getLocalPlayerPed();
|
|
145
91
|
}
|
|
146
|
-
/**
|
|
147
|
-
* Gets vehicle speed in km/h.
|
|
148
|
-
*
|
|
149
|
-
* @param vehicle - Vehicle handle
|
|
150
|
-
*/
|
|
151
92
|
getSpeed(vehicle) {
|
|
152
|
-
if (!
|
|
93
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
153
94
|
return 0;
|
|
154
|
-
return
|
|
95
|
+
return this.platform.getEntitySpeed(vehicle) * 3.6;
|
|
155
96
|
}
|
|
156
|
-
/**
|
|
157
|
-
* Gets the network ID from a vehicle handle.
|
|
158
|
-
*
|
|
159
|
-
* @param vehicle - Vehicle handle
|
|
160
|
-
* @returns Network ID or 0 if invalid
|
|
161
|
-
*/
|
|
162
97
|
getNetworkId(vehicle) {
|
|
163
|
-
if (!
|
|
98
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
164
99
|
return 0;
|
|
165
|
-
return
|
|
100
|
+
return this.platform.networkGetNetworkIdFromEntity(vehicle);
|
|
166
101
|
}
|
|
167
|
-
/**
|
|
168
|
-
* Gets the vehicle handle from a network ID.
|
|
169
|
-
*
|
|
170
|
-
* @param networkId - Network ID
|
|
171
|
-
* @returns Vehicle handle or 0 if not found
|
|
172
|
-
*/
|
|
173
102
|
getVehicleFromNetworkId(networkId) {
|
|
174
|
-
if (!
|
|
103
|
+
if (!this.platform.networkDoesEntityExistWithNetworkId(networkId))
|
|
175
104
|
return 0;
|
|
176
|
-
return
|
|
105
|
+
return this.platform.networkGetEntityFromNetworkId(networkId);
|
|
177
106
|
}
|
|
178
|
-
/**
|
|
179
|
-
* Gets vehicle data from state bag.
|
|
180
|
-
*
|
|
181
|
-
* @param vehicle - Vehicle handle
|
|
182
|
-
* @param key - State bag key
|
|
183
|
-
* @returns State value or undefined
|
|
184
|
-
*/
|
|
185
107
|
getVehicleState(vehicle, key) {
|
|
186
|
-
if (!
|
|
108
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
187
109
|
return undefined;
|
|
188
|
-
|
|
189
|
-
return stateBag[key];
|
|
110
|
+
return this.platform.getEntityState(vehicle, key);
|
|
190
111
|
}
|
|
191
|
-
/**
|
|
192
|
-
* Requests to lock/unlock vehicle doors.
|
|
193
|
-
*
|
|
194
|
-
* @param networkId - Network ID of the vehicle
|
|
195
|
-
* @param locked - Whether to lock or unlock
|
|
196
|
-
*/
|
|
197
112
|
setDoorsLocked(networkId, locked) {
|
|
198
|
-
|
|
113
|
+
this.events.emit('opencore:vehicle:setLocked', networkId, locked);
|
|
199
114
|
}
|
|
200
|
-
/**
|
|
201
|
-
* Requests vehicle data from the server.
|
|
202
|
-
*
|
|
203
|
-
* @param networkId - Network ID of the vehicle
|
|
204
|
-
* @returns Promise resolving to vehicle data
|
|
205
|
-
*/
|
|
206
115
|
async getVehicleData(networkId) {
|
|
207
116
|
return new Promise((resolve) => {
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
};
|
|
211
|
-
const eventName = 'opencore:vehicle:dataResult';
|
|
212
|
-
onNet(eventName, handler);
|
|
213
|
-
emitNet('opencore:vehicle:getData', networkId);
|
|
117
|
+
this.pendingData.set(networkId, resolve);
|
|
118
|
+
this.events.emit('opencore:vehicle:getData', networkId);
|
|
214
119
|
setTimeout(() => {
|
|
215
|
-
|
|
120
|
+
if (!this.pendingData.has(networkId))
|
|
121
|
+
return;
|
|
122
|
+
this.pendingData.delete(networkId);
|
|
216
123
|
resolve(null);
|
|
217
124
|
}, 5000);
|
|
218
125
|
});
|
|
219
126
|
}
|
|
220
|
-
/**
|
|
221
|
-
* Requests all player vehicles from the server.
|
|
222
|
-
*
|
|
223
|
-
* @returns Promise resolving to array of vehicle data
|
|
224
|
-
*/
|
|
225
127
|
async getPlayerVehicles() {
|
|
226
128
|
return new Promise((resolve) => {
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
};
|
|
230
|
-
const eventName = 'opencore:vehicle:playerVehiclesResult';
|
|
231
|
-
onNet(eventName, handler);
|
|
232
|
-
emitNet('opencore:vehicle:getPlayerVehicles');
|
|
129
|
+
this.pendingPlayerVehicles = resolve;
|
|
130
|
+
this.events.emit('opencore:vehicle:getPlayerVehicles');
|
|
233
131
|
setTimeout(() => {
|
|
234
|
-
|
|
132
|
+
if (!this.pendingPlayerVehicles)
|
|
133
|
+
return;
|
|
134
|
+
this.pendingPlayerVehicles = null;
|
|
235
135
|
resolve([]);
|
|
236
136
|
}, 5000);
|
|
237
137
|
});
|
|
238
138
|
}
|
|
239
|
-
/**
|
|
240
|
-
* Local-only: Warps player into a vehicle.
|
|
241
|
-
*
|
|
242
|
-
* @param vehicle - Vehicle handle
|
|
243
|
-
* @param seatIndex - Seat index (-1 = driver)
|
|
244
|
-
*/
|
|
245
139
|
warpIntoVehicle(vehicle, seatIndex = -1) {
|
|
246
|
-
if (!
|
|
140
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
247
141
|
return;
|
|
248
|
-
|
|
142
|
+
this.platform.taskWarpPedIntoVehicle(this.platform.getLocalPlayerPed(), vehicle, seatIndex);
|
|
249
143
|
}
|
|
250
|
-
/**
|
|
251
|
-
* Local-only: Sets vehicle heading.
|
|
252
|
-
*
|
|
253
|
-
* @param vehicle - Vehicle handle
|
|
254
|
-
* @param heading - Heading in degrees
|
|
255
|
-
*/
|
|
256
144
|
setHeading(vehicle, heading) {
|
|
257
|
-
if (!
|
|
145
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
258
146
|
return;
|
|
259
|
-
|
|
147
|
+
this.platform.setEntityHeading(vehicle, heading);
|
|
260
148
|
}
|
|
261
|
-
/**
|
|
262
|
-
* Local-only: Gets vehicle position.
|
|
263
|
-
*
|
|
264
|
-
* @param vehicle - Vehicle handle
|
|
265
|
-
* @returns Position vector
|
|
266
|
-
*/
|
|
267
149
|
getPosition(vehicle) {
|
|
268
|
-
if (!
|
|
150
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
269
151
|
return null;
|
|
270
|
-
|
|
271
|
-
return { x: coords[0], y: coords[1], z: coords[2] };
|
|
152
|
+
return this.platform.getEntityCoords(vehicle);
|
|
272
153
|
}
|
|
273
|
-
/**
|
|
274
|
-
* Local-only: Gets vehicle heading.
|
|
275
|
-
*
|
|
276
|
-
* @param vehicle - Vehicle handle
|
|
277
|
-
* @returns Heading in degrees
|
|
278
|
-
*/
|
|
279
154
|
getHeading(vehicle) {
|
|
280
|
-
if (!
|
|
155
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
281
156
|
return 0;
|
|
282
|
-
return
|
|
157
|
+
return this.platform.getEntityHeading(vehicle);
|
|
283
158
|
}
|
|
284
|
-
/**
|
|
285
|
-
* Local-only: Gets vehicle model hash.
|
|
286
|
-
*
|
|
287
|
-
* @param vehicle - Vehicle handle
|
|
288
|
-
* @returns Model hash
|
|
289
|
-
*/
|
|
290
159
|
getModel(vehicle) {
|
|
291
|
-
if (!
|
|
160
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
292
161
|
return 0;
|
|
293
|
-
return
|
|
162
|
+
return this.platform.getEntityModel(vehicle);
|
|
294
163
|
}
|
|
295
|
-
/**
|
|
296
|
-
* Local-only: Gets vehicle license plate.
|
|
297
|
-
*
|
|
298
|
-
* @param vehicle - Vehicle handle
|
|
299
|
-
* @returns License plate text
|
|
300
|
-
*/
|
|
301
164
|
getPlate(vehicle) {
|
|
302
|
-
if (!
|
|
165
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
303
166
|
return '';
|
|
304
|
-
return
|
|
167
|
+
return this.platform.getVehicleNumberPlateText(vehicle);
|
|
305
168
|
}
|
|
306
|
-
/**
|
|
307
|
-
* Applies vehicle mods from state bag data.
|
|
308
|
-
*
|
|
309
|
-
* @param vehicle - Vehicle handle
|
|
310
|
-
* @param mods - Mods object from state bag
|
|
311
|
-
*/
|
|
312
169
|
applyMods(vehicle, mods) {
|
|
313
|
-
if (!
|
|
170
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
314
171
|
return;
|
|
315
|
-
|
|
172
|
+
this.platform.setVehicleModKit(vehicle, 0);
|
|
316
173
|
if (mods.spoiler !== undefined)
|
|
317
|
-
|
|
174
|
+
this.platform.setVehicleMod(vehicle, 0, mods.spoiler, false);
|
|
318
175
|
if (mods.frontBumper !== undefined)
|
|
319
|
-
|
|
176
|
+
this.platform.setVehicleMod(vehicle, 1, mods.frontBumper, false);
|
|
320
177
|
if (mods.rearBumper !== undefined)
|
|
321
|
-
|
|
178
|
+
this.platform.setVehicleMod(vehicle, 2, mods.rearBumper, false);
|
|
322
179
|
if (mods.sideSkirt !== undefined)
|
|
323
|
-
|
|
180
|
+
this.platform.setVehicleMod(vehicle, 3, mods.sideSkirt, false);
|
|
324
181
|
if (mods.exhaust !== undefined)
|
|
325
|
-
|
|
182
|
+
this.platform.setVehicleMod(vehicle, 4, mods.exhaust, false);
|
|
326
183
|
if (mods.frame !== undefined)
|
|
327
|
-
|
|
184
|
+
this.platform.setVehicleMod(vehicle, 5, mods.frame, false);
|
|
328
185
|
if (mods.grille !== undefined)
|
|
329
|
-
|
|
186
|
+
this.platform.setVehicleMod(vehicle, 6, mods.grille, false);
|
|
330
187
|
if (mods.hood !== undefined)
|
|
331
|
-
|
|
188
|
+
this.platform.setVehicleMod(vehicle, 7, mods.hood, false);
|
|
332
189
|
if (mods.fender !== undefined)
|
|
333
|
-
|
|
190
|
+
this.platform.setVehicleMod(vehicle, 8, mods.fender, false);
|
|
334
191
|
if (mods.rightFender !== undefined)
|
|
335
|
-
|
|
192
|
+
this.platform.setVehicleMod(vehicle, 9, mods.rightFender, false);
|
|
336
193
|
if (mods.roof !== undefined)
|
|
337
|
-
|
|
194
|
+
this.platform.setVehicleMod(vehicle, 10, mods.roof, false);
|
|
338
195
|
if (mods.engine !== undefined)
|
|
339
|
-
|
|
196
|
+
this.platform.setVehicleMod(vehicle, 11, mods.engine, false);
|
|
340
197
|
if (mods.brakes !== undefined)
|
|
341
|
-
|
|
198
|
+
this.platform.setVehicleMod(vehicle, 12, mods.brakes, false);
|
|
342
199
|
if (mods.transmission !== undefined)
|
|
343
|
-
|
|
200
|
+
this.platform.setVehicleMod(vehicle, 13, mods.transmission, false);
|
|
344
201
|
if (mods.horns !== undefined)
|
|
345
|
-
|
|
202
|
+
this.platform.setVehicleMod(vehicle, 14, mods.horns, false);
|
|
346
203
|
if (mods.suspension !== undefined)
|
|
347
|
-
|
|
204
|
+
this.platform.setVehicleMod(vehicle, 15, mods.suspension, false);
|
|
348
205
|
if (mods.armor !== undefined)
|
|
349
|
-
|
|
206
|
+
this.platform.setVehicleMod(vehicle, 16, mods.armor, false);
|
|
350
207
|
if (mods.turbo !== undefined)
|
|
351
|
-
|
|
208
|
+
this.platform.toggleVehicleMod(vehicle, 18, mods.turbo);
|
|
352
209
|
if (mods.xenon !== undefined)
|
|
353
|
-
|
|
210
|
+
this.platform.toggleVehicleMod(vehicle, 22, mods.xenon);
|
|
354
211
|
if (mods.wheelType !== undefined)
|
|
355
|
-
|
|
212
|
+
this.platform.setVehicleWheelType(vehicle, mods.wheelType);
|
|
356
213
|
if (mods.wheels !== undefined)
|
|
357
|
-
|
|
214
|
+
this.platform.setVehicleMod(vehicle, 23, mods.wheels, false);
|
|
358
215
|
if (mods.windowTint !== undefined)
|
|
359
|
-
|
|
216
|
+
this.platform.setVehicleWindowTint(vehicle, mods.windowTint);
|
|
360
217
|
if (mods.livery !== undefined)
|
|
361
|
-
|
|
218
|
+
this.platform.setVehicleLivery(vehicle, mods.livery);
|
|
362
219
|
if (mods.plateStyle !== undefined)
|
|
363
|
-
|
|
220
|
+
this.platform.setVehicleNumberPlateTextIndex(vehicle, mods.plateStyle);
|
|
364
221
|
if (mods.neonEnabled !== undefined) {
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
222
|
+
this.platform.setVehicleNeonLightEnabled(vehicle, 0, mods.neonEnabled[0]);
|
|
223
|
+
this.platform.setVehicleNeonLightEnabled(vehicle, 1, mods.neonEnabled[1]);
|
|
224
|
+
this.platform.setVehicleNeonLightEnabled(vehicle, 2, mods.neonEnabled[2]);
|
|
225
|
+
this.platform.setVehicleNeonLightEnabled(vehicle, 3, mods.neonEnabled[3]);
|
|
369
226
|
}
|
|
370
227
|
if (mods.neonColor !== undefined) {
|
|
371
|
-
|
|
228
|
+
this.platform.setVehicleNeonLightsColour(vehicle, mods.neonColor[0], mods.neonColor[1], mods.neonColor[2]);
|
|
372
229
|
}
|
|
373
230
|
if (mods.extras) {
|
|
374
231
|
for (const [extraId, enabled] of Object.entries(mods.extras)) {
|
|
375
|
-
|
|
232
|
+
this.platform.setVehicleExtra(vehicle, Number(extraId), !enabled);
|
|
376
233
|
}
|
|
377
234
|
}
|
|
378
235
|
if (mods.pearlescentColor !== undefined || mods.wheelColor !== undefined) {
|
|
379
|
-
const [currentPearl, currentWheel] =
|
|
380
|
-
|
|
236
|
+
const [currentPearl, currentWheel] = this.platform.getVehicleExtraColours(vehicle);
|
|
237
|
+
this.platform.setVehicleExtraColours(vehicle, mods.pearlescentColor ?? currentPearl, mods.wheelColor ?? currentWheel);
|
|
381
238
|
}
|
|
382
239
|
}
|
|
383
|
-
/**
|
|
384
|
-
* Repairs a vehicle completely (client-side).
|
|
385
|
-
*
|
|
386
|
-
* @param vehicle - Vehicle handle
|
|
387
|
-
*/
|
|
388
240
|
repair(vehicle) {
|
|
389
|
-
if (!
|
|
241
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
390
242
|
return;
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
243
|
+
this.platform.setVehicleFixed(vehicle);
|
|
244
|
+
this.platform.setVehicleDeformationFixed(vehicle);
|
|
245
|
+
this.platform.setVehicleUndriveable(vehicle, false);
|
|
246
|
+
this.platform.setVehicleEngineOn(vehicle, true, true, false);
|
|
247
|
+
this.platform.setVehicleEngineHealth(vehicle, 1000.0);
|
|
248
|
+
this.platform.setVehiclePetrolTankHealth(vehicle, 1000.0);
|
|
397
249
|
}
|
|
398
|
-
/**
|
|
399
|
-
* Sets fuel level on a vehicle (client-side).
|
|
400
|
-
*
|
|
401
|
-
* @param vehicle - Vehicle handle
|
|
402
|
-
* @param level - Fuel level (0-100)
|
|
403
|
-
*/
|
|
404
250
|
setFuel(vehicle, level) {
|
|
405
|
-
if (!
|
|
251
|
+
if (!this.platform.doesEntityExist(vehicle))
|
|
406
252
|
return;
|
|
407
|
-
|
|
253
|
+
this.platform.setVehicleFuelLevel(vehicle, Math.max(0, Math.min(100, level)));
|
|
408
254
|
}
|
|
409
|
-
/**
|
|
410
|
-
* Registers event handlers for server responses.
|
|
411
|
-
*/
|
|
412
255
|
registerEventHandlers() {
|
|
413
|
-
|
|
414
|
-
if (result._requestId
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
256
|
+
this.events.on('opencore:vehicle:createResult', (_ctx, result) => {
|
|
257
|
+
if (result._requestId === undefined)
|
|
258
|
+
return;
|
|
259
|
+
const callback = this.pendingCreations.get(result._requestId);
|
|
260
|
+
if (!callback)
|
|
261
|
+
return;
|
|
262
|
+
callback(result);
|
|
263
|
+
this.pendingCreations.delete(result._requestId);
|
|
421
264
|
});
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
this.applyMods(veh, data.mods);
|
|
436
|
-
}
|
|
437
|
-
// Apply fuel from metadata
|
|
438
|
-
if (data.metadata?.fuel !== undefined) {
|
|
439
|
-
this.setFuel(veh, data.metadata.fuel);
|
|
440
|
-
}
|
|
441
|
-
}
|
|
265
|
+
this.events.on('opencore:vehicle:deleteResult', (_ctx, result) => {
|
|
266
|
+
const callback = this.pendingDeletes.get(result.networkId);
|
|
267
|
+
if (!callback)
|
|
268
|
+
return;
|
|
269
|
+
callback(result.success);
|
|
270
|
+
this.pendingDeletes.delete(result.networkId);
|
|
271
|
+
});
|
|
272
|
+
this.events.on('opencore:vehicle:repairResult', (_ctx, result) => {
|
|
273
|
+
const callback = this.pendingRepairs.get(result.networkId);
|
|
274
|
+
if (!callback)
|
|
275
|
+
return;
|
|
276
|
+
callback(result.success);
|
|
277
|
+
this.pendingRepairs.delete(result.networkId);
|
|
442
278
|
});
|
|
443
|
-
|
|
444
|
-
|
|
279
|
+
this.events.on('opencore:vehicle:dataResult', (_ctx, data) => {
|
|
280
|
+
if (!data)
|
|
281
|
+
return;
|
|
282
|
+
const callback = this.pendingData.get(data.networkId);
|
|
283
|
+
if (!callback)
|
|
284
|
+
return;
|
|
285
|
+
callback(data);
|
|
286
|
+
this.pendingData.delete(data.networkId);
|
|
445
287
|
});
|
|
446
|
-
|
|
288
|
+
this.events.on('opencore:vehicle:playerVehiclesResult', (_ctx, vehicles) => {
|
|
289
|
+
this.pendingPlayerVehicles?.(vehicles);
|
|
290
|
+
this.pendingPlayerVehicles = null;
|
|
291
|
+
});
|
|
292
|
+
this.events.on('opencore:vehicle:created', async (_ctx, data) => {
|
|
293
|
+
const veh = await this.waitForVehicle(data.networkId);
|
|
294
|
+
if (!veh)
|
|
295
|
+
return;
|
|
296
|
+
if (data.mods && Object.keys(data.mods).length > 0)
|
|
297
|
+
this.applyMods(veh, data.mods);
|
|
298
|
+
if (data.metadata?.fuel !== undefined)
|
|
299
|
+
this.setFuel(veh, data.metadata.fuel);
|
|
300
|
+
});
|
|
301
|
+
this.events.on('opencore:vehicle:modified', (_ctx, data) => {
|
|
447
302
|
const veh = this.getVehicleFromNetworkId(data.networkId);
|
|
448
|
-
if (veh &&
|
|
303
|
+
if (veh && this.platform.doesEntityExist(veh))
|
|
449
304
|
this.applyMods(veh, data.mods);
|
|
450
|
-
}
|
|
451
305
|
});
|
|
452
|
-
|
|
306
|
+
this.events.on('opencore:vehicle:repaired', (_ctx, networkId) => {
|
|
453
307
|
const veh = this.getVehicleFromNetworkId(networkId);
|
|
454
|
-
if (veh &&
|
|
308
|
+
if (veh && this.platform.doesEntityExist(veh))
|
|
455
309
|
this.repair(veh);
|
|
456
|
-
}
|
|
457
|
-
});
|
|
458
|
-
onNet('opencore:vehicle:lockedChanged', (data) => {
|
|
459
|
-
console.log('[VehicleClient] Vehicle lock changed:', data.networkId, data.locked);
|
|
460
310
|
});
|
|
461
|
-
|
|
462
|
-
const
|
|
463
|
-
|
|
464
|
-
while (GetGameTimer() - started < 5000) {
|
|
465
|
-
veh = this.getVehicleFromNetworkId(networkId);
|
|
466
|
-
if (veh && DoesEntityExist(veh))
|
|
467
|
-
break;
|
|
468
|
-
await new Promise((r) => setTimeout(r, 0));
|
|
469
|
-
}
|
|
470
|
-
if (veh && DoesEntityExist(veh)) {
|
|
311
|
+
this.events.on('opencore:vehicle:warpInto', async (_ctx, networkId, seatIndex = -1) => {
|
|
312
|
+
const veh = await this.waitForVehicle(networkId);
|
|
313
|
+
if (veh)
|
|
471
314
|
this.warpIntoVehicle(veh, seatIndex);
|
|
472
|
-
}
|
|
473
|
-
else {
|
|
474
|
-
console.error('[VehicleClient] Failed to warp into vehicle:', networkId);
|
|
475
|
-
}
|
|
476
315
|
});
|
|
477
316
|
}
|
|
317
|
+
async waitForVehicle(networkId) {
|
|
318
|
+
const started = this.runtime.getGameTimer();
|
|
319
|
+
while (this.runtime.getGameTimer() - started < 5000) {
|
|
320
|
+
const veh = this.getVehicleFromNetworkId(networkId);
|
|
321
|
+
if (veh && this.platform.doesEntityExist(veh))
|
|
322
|
+
return veh;
|
|
323
|
+
await new Promise((r) => setTimeout(r, 0));
|
|
324
|
+
}
|
|
325
|
+
return null;
|
|
326
|
+
}
|
|
478
327
|
};
|
|
479
328
|
VehicleClientService = __decorate([
|
|
480
329
|
injectable(),
|
|
481
|
-
|
|
330
|
+
__param(0, inject(EventsAPI)),
|
|
331
|
+
__param(1, inject(IClientPlatformBridge)),
|
|
332
|
+
__param(2, inject(IClientRuntimeBridge)),
|
|
333
|
+
__metadata("design:paramtypes", [EventsAPI,
|
|
334
|
+
IClientPlatformBridge,
|
|
335
|
+
IClientRuntimeBridge])
|
|
482
336
|
], VehicleClientService);
|
|
483
337
|
export { VehicleClientService };
|