@ragemp-mango/webview 2.0.6-beta.0

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2024 Aurėjus Remeika
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,20 @@
1
+ ## Mango Framework
2
+
3
+ A simple, lightweight, and powerful TypeScript framework for building RageMP servers.
4
+
5
+ ## Features
6
+
7
+ - Mango Framework is built with TypeScript and provides a powerful type system for your application.
8
+ - Mango Framework has a wide range of decorators that allow you to easily create and manage your resource flow.
9
+ - Mango Framework is built with modularity in mind, allowing you to organize your application into small, reusable pieces.
10
+ - Mango Framework uses InversifyJS under the hood to provide a powerful dependency injection for your application.
11
+ - Mango Framework uses controllers to group and listen to events/rpcs together under a single class.
12
+ - Mango Framework uses Guards, Interceptors, and Error Filters to create a powerful pipeline that allows you to easily manage every incoming event/rpc.
13
+
14
+ ## Documentation
15
+
16
+ [Documentation](https://ragemp-mango.vercel.app)
17
+
18
+ ## License
19
+
20
+ [MIT](https://choosealicense.com/licenses/mit/)
@@ -0,0 +1,72 @@
1
+ import { RPCCallOptions, RPCResult, ScriptRPCHandler, LoggerService } from '@ragemp-mango/core/interfaces';
2
+
3
+ interface ScriptEventHandler {
4
+ destroy(): void;
5
+ valid?: boolean;
6
+ }
7
+
8
+ interface EventService {
9
+ on<E extends keyof MangoEvents.CustomWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
10
+ on<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
11
+ once<E extends keyof MangoEvents.CustomWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
12
+ once<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
13
+ emit<E extends keyof MangoEvents.CustomWebViewEvent>(eventName: E, body?: Parameters<MangoEvents.CustomWebViewEvent[E]>[0]): void;
14
+ emit<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomWebViewEvent>, body?: unknown): void;
15
+ onPlayer<E extends keyof MangoEvents.CustomClientToWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomClientToWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
16
+ onPlayer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomClientToWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
17
+ oncePlayer<E extends keyof MangoEvents.CustomClientToWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomClientToWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
18
+ oncePlayer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomClientToWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
19
+ emitPlayer<E extends keyof MangoEvents.CustomWebViewToClientEvent>(eventName: E, body?: Parameters<MangoEvents.CustomWebViewToClientEvent[E]>[0]): void;
20
+ emitPlayer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomWebViewToClientEvent>, body?: unknown): void;
21
+ onServer<E extends keyof MangoEvents.CustomServerToWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomServerToWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
22
+ onServer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomServerToWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
23
+ onceServer<E extends keyof MangoEvents.CustomServerToWebViewEvent>(eventName: E, callback: (body: Parameters<MangoEvents.CustomServerToWebViewEvent[E]>[0]) => void | Promise<void>): ScriptEventHandler;
24
+ onceServer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomServerToWebViewEvent>, callback: (body: unknown) => void | Promise<void>): ScriptEventHandler;
25
+ emitServer<E extends keyof MangoEvents.CustomWebViewToServerEvent>(eventName: E, body?: Parameters<MangoEvents.CustomWebViewToServerEvent[E]>[0]): void;
26
+ emitServer<E extends string>(eventName: Exclude<E, keyof MangoEvents.CustomWebViewToServerEvent>, body?: unknown): void;
27
+ }
28
+
29
+ interface RPCService {
30
+ call<E extends keyof MangoRPC.CustomWebViewRPC>(rpcName: E, body?: Parameters<MangoRPC.CustomWebViewRPC[E]>[0], options?: RPCCallOptions): Promise<RPCResult<ReturnType<MangoRPC.CustomWebViewRPC[E]>>>;
31
+ call<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomWebViewRPC>, body?: unknown, options?: RPCCallOptions): Promise<RPCResult>;
32
+ onRequest<E extends keyof MangoRPC.CustomWebViewRPC>(rpcName: E, handler: (body: Parameters<MangoRPC.CustomWebViewRPC[E]>[0]) => ReturnType<MangoRPC.CustomWebViewRPC[E]>): ScriptRPCHandler;
33
+ onRequest<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomWebViewRPC>, handler: (body: unknown) => unknown | Promise<unknown>): ScriptRPCHandler;
34
+ callServer<E extends keyof MangoRPC.CustomWebViewToServerRPC>(rpcName: E, body?: Parameters<MangoRPC.CustomWebViewToServerRPC[E]>[0], options?: RPCCallOptions): Promise<RPCResult<ReturnType<MangoRPC.CustomWebViewToServerRPC[E]>>>;
35
+ callServer<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomWebViewToServerRPC>, body?: unknown, options?: RPCCallOptions): Promise<RPCResult>;
36
+ onServerRequest<E extends keyof MangoRPC.CustomServerToWebViewRPC>(rpcName: E, handler: (body: Parameters<MangoRPC.CustomServerToWebViewRPC[E]>[0]) => ReturnType<MangoRPC.CustomServerToWebViewRPC[E]>): ScriptRPCHandler;
37
+ onServerRequest<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomServerToWebViewRPC>, handler: (body: unknown) => unknown | Promise<unknown>): ScriptRPCHandler;
38
+ callPlayer<E extends keyof MangoRPC.CustomWebViewToClientRPC>(rpcName: E, body?: Parameters<MangoRPC.CustomWebViewToClientRPC[E]>[0], options?: RPCCallOptions): Promise<RPCResult<ReturnType<MangoRPC.CustomWebViewToClientRPC[E]>>>;
39
+ callPlayer<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomWebViewToClientRPC>, body?: unknown, options?: RPCCallOptions): Promise<RPCResult>;
40
+ onPlayerRequest<E extends keyof MangoRPC.CustomClientToWebviewRPC>(rpcName: E, handler: (body: Parameters<MangoRPC.CustomClientToWebviewRPC[E]>[0]) => ReturnType<MangoRPC.CustomClientToWebviewRPC[E]>): ScriptRPCHandler;
41
+ onPlayerRequest<E extends string>(rpcName: Exclude<E, keyof MangoRPC.CustomClientToWebviewRPC>, handler: (body: unknown) => unknown | Promise<unknown>): ScriptRPCHandler;
42
+ }
43
+
44
+ // RageMP WebView type extensions
45
+ // These are empty placeholders - extend MangoEvents and MangoRPC namespaces in your project
46
+
47
+ declare global {
48
+ namespace MangoEvents {
49
+ // Extend these in your project
50
+ }
51
+
52
+ namespace MangoRPC {
53
+ // Extend these in your project
54
+ }
55
+ }
56
+
57
+ declare function initMango(): {
58
+ event: EventService;
59
+ rpc: RPCService;
60
+ logger: LoggerService;
61
+ };
62
+ declare global {
63
+ export interface Window {
64
+ mango: {
65
+ event: EventService;
66
+ rpc: RPCService;
67
+ logger: LoggerService;
68
+ };
69
+ }
70
+ }
71
+
72
+ export { initMango };
package/dist/index.js ADDED
@@ -0,0 +1,535 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/services/webview-logger.service.ts
5
+ var WebViewLoggerService = class {
6
+ static {
7
+ __name(this, "WebViewLoggerService");
8
+ }
9
+ log(...args) {
10
+ console.log(`[\u{1F96D}WebView][Log]`, ...args);
11
+ }
12
+ error(...args) {
13
+ console.error(`[\u{1F96D}WebView][Error]`, ...args);
14
+ }
15
+ warn(...args) {
16
+ console.warn(`[\u{1F96D}WebView][Warn]`, ...args);
17
+ }
18
+ debug(...args) {
19
+ console.debug(`[\u{1F96D}WebView][Debug]`, ...args);
20
+ }
21
+ };
22
+
23
+ // src/services/webview-event.service.ts
24
+ var WebViewEventService = class {
25
+ static {
26
+ __name(this, "WebViewEventService");
27
+ }
28
+ $localHandlers = /* @__PURE__ */ new Map();
29
+ $remoteHandlers = /* @__PURE__ */ new Map();
30
+ on(eventName, callback) {
31
+ const eventHandler = {
32
+ destroy: /* @__PURE__ */ __name(() => {
33
+ eventHandler.valid = false;
34
+ const handlers = this.$localHandlers.get(eventName);
35
+ handlers?.delete(eventHandler);
36
+ }, "destroy"),
37
+ eventName,
38
+ handler: callback,
39
+ local: true,
40
+ onlyOnce: false,
41
+ remote: false,
42
+ valid: true
43
+ };
44
+ if (!this.$localHandlers.has(eventName)) {
45
+ this.$localHandlers.set(eventName, /* @__PURE__ */ new Set());
46
+ }
47
+ this.$localHandlers.get(eventName).add(eventHandler);
48
+ return eventHandler;
49
+ }
50
+ once(eventName, callback) {
51
+ const eventHandler = {
52
+ destroy: /* @__PURE__ */ __name(() => {
53
+ eventHandler.valid = false;
54
+ const handlers = this.$localHandlers.get(eventName);
55
+ handlers?.delete(eventHandler);
56
+ }, "destroy"),
57
+ eventName,
58
+ handler: callback,
59
+ local: true,
60
+ onlyOnce: true,
61
+ remote: false,
62
+ valid: true
63
+ };
64
+ if (!this.$localHandlers.has(eventName)) {
65
+ this.$localHandlers.set(eventName, /* @__PURE__ */ new Set());
66
+ }
67
+ this.$localHandlers.get(eventName).add(eventHandler);
68
+ return eventHandler;
69
+ }
70
+ emit(eventName, body) {
71
+ const listeners = this.$localHandlers.get(eventName);
72
+ listeners?.forEach((scriptEventHandler) => {
73
+ scriptEventHandler.handler(body);
74
+ if (!scriptEventHandler.onlyOnce) return;
75
+ scriptEventHandler.destroy();
76
+ });
77
+ }
78
+ onPlayer(eventName, callback) {
79
+ const wrapper = /* @__PURE__ */ __name((...args) => callback(args[0]), "wrapper");
80
+ const eventHandler = {
81
+ destroy: /* @__PURE__ */ __name(() => {
82
+ eventHandler.valid = false;
83
+ const handlers = this.$remoteHandlers.get(eventName);
84
+ handlers?.delete(eventHandler);
85
+ }, "destroy"),
86
+ eventName,
87
+ handler: wrapper,
88
+ local: false,
89
+ onlyOnce: false,
90
+ remote: true,
91
+ valid: true
92
+ };
93
+ if (typeof window.mp !== "undefined") {
94
+ window.mp.events.add(eventName, wrapper);
95
+ }
96
+ if (!this.$remoteHandlers.has(eventName)) {
97
+ this.$remoteHandlers.set(eventName, /* @__PURE__ */ new Set());
98
+ }
99
+ this.$remoteHandlers.get(eventName).add(eventHandler);
100
+ return eventHandler;
101
+ }
102
+ oncePlayer(eventName, callback) {
103
+ const wrapper = /* @__PURE__ */ __name((...args) => {
104
+ callback(args[0]);
105
+ eventHandler.destroy();
106
+ }, "wrapper");
107
+ const eventHandler = {
108
+ destroy: /* @__PURE__ */ __name(() => {
109
+ eventHandler.valid = false;
110
+ const handlers = this.$remoteHandlers.get(eventName);
111
+ handlers?.delete(eventHandler);
112
+ }, "destroy"),
113
+ eventName,
114
+ handler: wrapper,
115
+ local: false,
116
+ onlyOnce: true,
117
+ remote: true,
118
+ valid: true
119
+ };
120
+ if (typeof window.mp !== "undefined") {
121
+ window.mp.events.add(eventName, wrapper);
122
+ }
123
+ if (!this.$remoteHandlers.has(eventName)) {
124
+ this.$remoteHandlers.set(eventName, /* @__PURE__ */ new Set());
125
+ }
126
+ this.$remoteHandlers.get(eventName).add(eventHandler);
127
+ return eventHandler;
128
+ }
129
+ emitPlayer(eventName, body) {
130
+ if (typeof window.mp !== "undefined") {
131
+ window.mp.trigger(eventName, body);
132
+ }
133
+ }
134
+ onServer(eventName, callback) {
135
+ return this.onPlayer(`WEBVIEW::ON_SERVER_${eventName}`, callback);
136
+ }
137
+ onceServer(eventName, callback) {
138
+ return this.oncePlayer(`WEBVIEW::ON_SERVER_${eventName}`, callback);
139
+ }
140
+ emitServer(eventName, body) {
141
+ if (typeof window.mp !== "undefined") {
142
+ window.mp.trigger("WEBVIEW::EMIT_SERVER", {
143
+ eventName,
144
+ payload: body
145
+ });
146
+ }
147
+ }
148
+ };
149
+
150
+ // ../core/dist/chunk-DXPVUDXD.js
151
+ var ErrorMessage = /* @__PURE__ */ (function(ErrorMessage2) {
152
+ ErrorMessage2["TooManyRequests"] = "Too many requests.";
153
+ ErrorMessage2["EventNameMustBeString"] = "The event name must be a string.";
154
+ ErrorMessage2["EventNameMustBeUnique"] = "The event name must be unique.";
155
+ ErrorMessage2["EventNotAllowedInClient"] = "The event is not allowed in the client environment.";
156
+ ErrorMessage2["EventNotAllowedInServer"] = "The event is not allowed in the server environment.";
157
+ ErrorMessage2["InvalidEventType"] = "Invalid event type.";
158
+ ErrorMessage2["InvalidInternalEventName"] = "The name of the internal event is invalid.";
159
+ ErrorMessage2["InvalidReturnInEvent"] = "Cannot return a value from an event.";
160
+ ErrorMessage2["RPCNameMustBeString"] = "The RPC name must be a string.";
161
+ ErrorMessage2["RPCNameMustBeUnique"] = "The RPC name must be unique.";
162
+ ErrorMessage2["RPCNotAllowedInClient"] = "The RPC is not allowed in the client environment.";
163
+ ErrorMessage2["RPCNotAllowedInServer"] = "The RPC is not allowed in the server environment.";
164
+ ErrorMessage2["InvalidRPCType"] = "Invalid RPC type.";
165
+ ErrorMessage2["RPCHandlerAlreadyExists"] = "The RPC handler already exists. Please provide a unique name for the RPC.";
166
+ ErrorMessage2["RPCResponseAlreadySent"] = "The RPC response has already been sent.";
167
+ ErrorMessage2["InvalidErrorFilterDefinition"] = "Invalid error filter. Error filters must be a class reference or an object with a catch method.";
168
+ ErrorMessage2["ErrorAlreadyHandledByFilter"] = "The error already points to a filter.";
169
+ ErrorMessage2["ExceptionHandlingConflict"] = "The same exception can only be caught once.";
170
+ ErrorMessage2["AtLeastOneFilterRequired"] = "At least one error filter must be provided.";
171
+ ErrorMessage2["DuplicateErrorFilterDetected"] = "Duplicate error filter found. Ensure that the same filter is not applied more than once.";
172
+ ErrorMessage2["WebViewNotFound"] = "The WebView with the specified id does not exist.";
173
+ ErrorMessage2["WebViewIdMustBeStringOrNumber"] = "The WebView id must be a string or number.";
174
+ ErrorMessage2["InvalidGuardDefinition"] = "Invalid guard. Guards must be a class reference or an object with a canActivate method.";
175
+ ErrorMessage2["AtLeastOneGuardRequired"] = "At least one guard must be provided.";
176
+ ErrorMessage2["InvalidInterceptorDefinition"] = "Invalid interceptor. Interceptors must be a class reference or an object with an intercept method.";
177
+ ErrorMessage2["AtLeastOneInterceptorRequired"] = "At least one interceptor must be provided.";
178
+ ErrorMessage2["InvalidInterceptorReturnValue"] = "The interceptor must return a function.";
179
+ ErrorMessage2["InvalidPipeDefinition"] = "Invalid pipe. Pipes must be a class reference or an object with a transform method.";
180
+ ErrorMessage2["AtLeastOnePipeRequired"] = "At least one pipe must be provided.";
181
+ ErrorMessage2["AppAlreadyLoaded"] = "App is already loaded. Please call the stop method before calling the start method.";
182
+ ErrorMessage2["AppNotLoaded"] = "App is not loaded. Please call the start method before calling the stop method.";
183
+ ErrorMessage2["InvalidInjectionTokenSpecified"] = "The specified injection token is invalid.";
184
+ ErrorMessage2["InjectionTokenNotFound"] = "The injection token could not be found.";
185
+ ErrorMessage2["ParamKeyMustBeString"] = "The param key must be a string.";
186
+ ErrorMessage2["IndexKeyMustBeNumber"] = "The index key must be a number.";
187
+ ErrorMessage2["DuplicateDecoratorUsage"] = "The same decorator can only be used once in the same class.";
188
+ ErrorMessage2["InvalidControllerOptions"] = "Invalid controller options found.";
189
+ ErrorMessage2["InvalidInjectableOptions"] = "Invalid injectable options found.";
190
+ ErrorMessage2["InvalidModuleOptions"] = "Invalid module options found.";
191
+ ErrorMessage2["MultipleDecoratorsOnSingleParameterNotAllowed"] = "Cannot apply multiple decorators to the same parameter.";
192
+ ErrorMessage2["CircularDependencyDetected"] = "Circular dependency detected.";
193
+ ErrorMessage2["InvalidModuleDefinition"] = "The module is invalid.";
194
+ ErrorMessage2["InvalidExportDefinition"] = "The export is invalid.";
195
+ ErrorMessage2["InvalidProviderDefinition"] = "The provider is invalid.";
196
+ ErrorMessage2["InvalidParameterDecoratorUsage"] = "Each parameter must have their its own decorator.";
197
+ ErrorMessage2["ResponseDecoratorNotAllowedOnEvents"] = "The @Response() decorator is not allowed on events.";
198
+ ErrorMessage2["PlayerDecoratorNotAllowedOnClientEvents"] = "The @Player() decorator is not allowed on client events.";
199
+ ErrorMessage2["TimerNameMustBeString"] = "The timer name must be a string.";
200
+ return ErrorMessage2;
201
+ })({});
202
+ var RPCResultStatus = /* @__PURE__ */ (function(RPCResultStatus2) {
203
+ RPCResultStatus2[RPCResultStatus2["Success"] = 1] = "Success";
204
+ RPCResultStatus2[RPCResultStatus2["Timeout"] = 2] = "Timeout";
205
+ RPCResultStatus2[RPCResultStatus2["HandlerNotFound"] = 3] = "HandlerNotFound";
206
+ RPCResultStatus2[RPCResultStatus2["Unknown"] = 4] = "Unknown";
207
+ RPCResultStatus2[RPCResultStatus2["CancelledByGuard"] = 5] = "CancelledByGuard";
208
+ RPCResultStatus2[RPCResultStatus2["InvalidGuardReturn"] = 6] = "InvalidGuardReturn";
209
+ RPCResultStatus2[RPCResultStatus2["TooManyRequests"] = 7] = "TooManyRequests";
210
+ RPCResultStatus2[RPCResultStatus2["PlayerDisconnected"] = 8] = "PlayerDisconnected";
211
+ RPCResultStatus2[RPCResultStatus2["PlayerNotFound"] = 9] = "PlayerNotFound";
212
+ return RPCResultStatus2;
213
+ })({});
214
+
215
+ // ../core/dist/chunk-HK7QTFPA.js
216
+ var RPC_RESULT_TIMEOUT = {
217
+ success: false,
218
+ error: {
219
+ message: "RPC call timed out."
220
+ },
221
+ status: RPCResultStatus.Timeout
222
+ };
223
+ var RPC_RESULT_HANDLER_NOT_FOUND = {
224
+ success: false,
225
+ error: {
226
+ message: "RPC handler not found."
227
+ },
228
+ status: RPCResultStatus.HandlerNotFound
229
+ };
230
+ var RPC_RESULT_UNKNOWN = {
231
+ success: false,
232
+ error: {
233
+ message: "Unknown error."
234
+ },
235
+ status: RPCResultStatus.Unknown
236
+ };
237
+ var RPC_RESULT_PLAYER_DISCONNECTED = {
238
+ success: false,
239
+ error: {
240
+ message: "Player disconnected."
241
+ },
242
+ status: RPCResultStatus.PlayerDisconnected
243
+ };
244
+ var RPC_RESULT_PLAYER_NOT_FOUND = {
245
+ success: false,
246
+ error: {
247
+ message: "Player not found."
248
+ },
249
+ status: RPCResultStatus.PlayerNotFound
250
+ };
251
+
252
+ // ../core/dist/chunk-7QVYU63E.js
253
+ var __defProp2 = Object.defineProperty;
254
+ var __name2 = /* @__PURE__ */ __name((target, value) => __defProp2(target, "name", {
255
+ value,
256
+ configurable: true
257
+ }), "__name");
258
+
259
+ // ../core/dist/chunk-E6IQL4S6.js
260
+ function generateRandomId() {
261
+ return Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
262
+ }
263
+ __name(generateRandomId, "generateRandomId");
264
+ __name2(generateRandomId, "generateRandomId");
265
+ var isUndefined = /* @__PURE__ */ __name2((obj) => typeof obj === "undefined", "isUndefined");
266
+ var isNil = /* @__PURE__ */ __name2((val) => isUndefined(val) || val === null, "isNil");
267
+
268
+ // ../core/dist/chunk-TBWHLT75.js
269
+ var EventDestination = /* @__PURE__ */ (function(EventDestination2) {
270
+ EventDestination2["Server"] = "server";
271
+ EventDestination2["Client"] = "client";
272
+ EventDestination2["WebView"] = "webview";
273
+ return EventDestination2;
274
+ })({});
275
+
276
+ // src/services/webview-rpc.service.ts
277
+ var WebViewRPCService = class {
278
+ static {
279
+ __name(this, "WebViewRPCService");
280
+ }
281
+ $eventService;
282
+ $loggerService;
283
+ $TIMEOUT = 2e3;
284
+ $localHandlers = /* @__PURE__ */ new Map();
285
+ $clientHandlers = /* @__PURE__ */ new Map();
286
+ $serverHandlers = /* @__PURE__ */ new Map();
287
+ constructor($eventService, $loggerService) {
288
+ this.$eventService = $eventService;
289
+ this.$loggerService = $loggerService;
290
+ }
291
+ async call(rpcName, body, options = {
292
+ timeout: this.$TIMEOUT
293
+ }) {
294
+ return new Promise(async (resolve) => {
295
+ const rpcHandler = this.$localHandlers.get(rpcName);
296
+ if (isNil(rpcHandler)) {
297
+ resolve(RPC_RESULT_HANDLER_NOT_FOUND);
298
+ return;
299
+ }
300
+ const timeoutId = setTimeout(() => {
301
+ resolve(RPC_RESULT_TIMEOUT);
302
+ }, options.timeout);
303
+ const result = await rpcHandler.handler(body);
304
+ clearTimeout(timeoutId);
305
+ resolve({
306
+ success: true,
307
+ status: RPCResultStatus.Success,
308
+ body: result,
309
+ error: void 0
310
+ });
311
+ });
312
+ }
313
+ onRequest(rpcName, handler) {
314
+ if (this.$localHandlers.has(rpcName)) {
315
+ this.$loggerService.error("An error occurred while registering a RPC handler.");
316
+ throw new Error(ErrorMessage.RPCHandlerAlreadyExists);
317
+ }
318
+ const rpcHandler = {
319
+ destroy: /* @__PURE__ */ __name(() => {
320
+ rpcHandler.valid = false;
321
+ this.$localHandlers.delete(rpcName);
322
+ }, "destroy"),
323
+ rpcName,
324
+ handler,
325
+ valid: true
326
+ };
327
+ this.$localHandlers.set(rpcName, rpcHandler);
328
+ return rpcHandler;
329
+ }
330
+ callServer(rpcName, body, options = {
331
+ timeout: this.$TIMEOUT
332
+ }) {
333
+ return this.$handleCall(rpcName, EventDestination.Server, options, body);
334
+ }
335
+ onServerRequest(rpcName, handler) {
336
+ if (this.$serverHandlers.has(rpcName)) {
337
+ this.$loggerService.error("An error occurred while registering a RPC handler.");
338
+ throw new Error(ErrorMessage.RPCHandlerAlreadyExists);
339
+ }
340
+ const rpcHandler = {
341
+ destroy: /* @__PURE__ */ __name(() => {
342
+ rpcHandler.valid = false;
343
+ this.$serverHandlers.delete(rpcName);
344
+ }, "destroy"),
345
+ rpcName,
346
+ handler,
347
+ valid: true
348
+ };
349
+ this.$serverHandlers.set(rpcName, rpcHandler);
350
+ return rpcHandler;
351
+ }
352
+ callPlayer(rpcName, body, options = {
353
+ timeout: this.$TIMEOUT
354
+ }) {
355
+ return this.$handleCall(rpcName, EventDestination.Client, options, body);
356
+ }
357
+ onPlayerRequest(rpcName, handler) {
358
+ if (this.$clientHandlers.has(rpcName)) {
359
+ this.$loggerService.error("An error occurred while registering a RPC listener.");
360
+ throw new Error(ErrorMessage.RPCHandlerAlreadyExists);
361
+ }
362
+ const rpcHandler = {
363
+ destroy: /* @__PURE__ */ __name(() => {
364
+ rpcHandler.valid = false;
365
+ this.$clientHandlers.delete(rpcName);
366
+ }, "destroy"),
367
+ rpcName,
368
+ handler,
369
+ valid: true
370
+ };
371
+ this.$clientHandlers.set(rpcName, rpcHandler);
372
+ return rpcHandler;
373
+ }
374
+ async $handleCall(rpcName, destination, options, body) {
375
+ return new Promise((resolve) => {
376
+ const callId = generateRandomId();
377
+ let timeoutId;
378
+ const onceHandle = /* @__PURE__ */ __name((body2) => {
379
+ clearTimeout(timeoutId);
380
+ resolve(body2);
381
+ }, "onceHandle");
382
+ const scriptEventHandler = destination === EventDestination.Server ? this.$eventService.onceServer(`RPC::RETURN_FROM_SERVER_${callId}`, onceHandle) : this.$eventService.oncePlayer(`RPC::RETURN_FROM_CLIENT_${callId}`, onceHandle);
383
+ const payload = {
384
+ source: EventDestination.WebView,
385
+ destination,
386
+ id: callId,
387
+ rpcName,
388
+ body
389
+ };
390
+ destination === EventDestination.Server ? this.$eventService.emitPlayer("RPC::CALL_SERVER", payload) : this.$eventService.emitPlayer("RPC::CALL_CLIENT", payload);
391
+ timeoutId = setTimeout(() => {
392
+ scriptEventHandler.destroy();
393
+ resolve(RPC_RESULT_TIMEOUT);
394
+ }, options?.timeout ?? this.$TIMEOUT);
395
+ });
396
+ }
397
+ };
398
+
399
+ // ../core/dist/chunk-6YEWPMZJ.js
400
+ var MangoError = class extends Error {
401
+ static {
402
+ __name(this, "MangoError");
403
+ }
404
+ static {
405
+ __name2(this, "MangoError");
406
+ }
407
+ status = RPCResultStatus.Unknown;
408
+ details;
409
+ constructor(message, status, details) {
410
+ super(message);
411
+ this.status = status ?? RPCResultStatus.Unknown;
412
+ this.details = details;
413
+ }
414
+ };
415
+ var GuardCancelError = class extends MangoError {
416
+ static {
417
+ __name(this, "GuardCancelError");
418
+ }
419
+ static {
420
+ __name2(this, "GuardCancelError");
421
+ }
422
+ constructor() {
423
+ super("Process cancelled by the guard.", RPCResultStatus.CancelledByGuard);
424
+ }
425
+ };
426
+ var GuardInvalidReturnError = class extends MangoError {
427
+ static {
428
+ __name(this, "GuardInvalidReturnError");
429
+ }
430
+ static {
431
+ __name2(this, "GuardInvalidReturnError");
432
+ }
433
+ constructor() {
434
+ super("Guard returned an invalid value. Expected boolean.", RPCResultStatus.InvalidGuardReturn);
435
+ }
436
+ };
437
+ var TooManyRequests = class extends MangoError {
438
+ static {
439
+ __name(this, "TooManyRequests");
440
+ }
441
+ static {
442
+ __name2(this, "TooManyRequests");
443
+ }
444
+ constructor(message = "Too many requests.") {
445
+ super(message, RPCResultStatus.TooManyRequests);
446
+ }
447
+ };
448
+ var UnknownError = class extends MangoError {
449
+ static {
450
+ __name(this, "UnknownError");
451
+ }
452
+ static {
453
+ __name2(this, "UnknownError");
454
+ }
455
+ constructor() {
456
+ super("Unknown error.", RPCResultStatus.Unknown);
457
+ }
458
+ };
459
+
460
+ // src/index.ts
461
+ function initMango() {
462
+ if (!isNil(window.mango)) {
463
+ return window.mango;
464
+ }
465
+ const event = new WebViewEventService();
466
+ const logger = new WebViewLoggerService();
467
+ const rpc = new WebViewRPCService(event, logger);
468
+ event.onServer("RPC::CALL_WEBVIEW", async (body) => {
469
+ const id = body.id;
470
+ const name = body.rpcName;
471
+ const payload = body.body;
472
+ const rpcHandler = rpc.$serverHandlers.get(name);
473
+ if (!rpcHandler) {
474
+ event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_HANDLER_NOT_FOUND);
475
+ return;
476
+ }
477
+ try {
478
+ const result = await rpcHandler.handler(payload);
479
+ const rpcResult = {
480
+ success: true,
481
+ status: RPCResultStatus.Success,
482
+ body: result
483
+ };
484
+ event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);
485
+ } catch (error) {
486
+ if (error instanceof MangoError) {
487
+ const rpcResult = {
488
+ success: false,
489
+ status: error.status,
490
+ error: {
491
+ message: error.message,
492
+ details: error.details
493
+ }
494
+ };
495
+ event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);
496
+ return;
497
+ }
498
+ event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_UNKNOWN);
499
+ }
500
+ });
501
+ event.onPlayer("RPC::CALL_WEBVIEW", async (body) => {
502
+ const id = body.id;
503
+ const name = body.rpcName;
504
+ const payload = body.body;
505
+ const rpcHandler = rpc.$clientHandlers.get(name);
506
+ if (isNil(rpcHandler)) {
507
+ event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_HANDLER_NOT_FOUND);
508
+ return;
509
+ }
510
+ try {
511
+ const result = await rpcHandler.handler(payload);
512
+ const rpcResult = {
513
+ success: true,
514
+ status: RPCResultStatus.Success,
515
+ body: result
516
+ };
517
+ event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);
518
+ } catch (error) {
519
+ event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_UNKNOWN);
520
+ }
521
+ });
522
+ const mango = {
523
+ event,
524
+ rpc,
525
+ logger
526
+ };
527
+ window.mango = mango;
528
+ logger.log("WebView initialized");
529
+ return mango;
530
+ }
531
+ __name(initMango, "initMango");
532
+ export {
533
+ initMango
534
+ };
535
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/services/webview-logger.service.ts", "../src/services/webview-event.service.ts", "../../core/src/enums/error-message.enum.ts", "../../core/src/enums/injectable-scope.enum.ts", "../../core/src/enums/rpc-result-status.enum.ts", "../../core/src/app/constants/index.ts", "../../core/dist/chunk-7QVYU63E.js", "../../core/src/utils/generate-random-id.util.ts", "../../core/src/utils/type-check.util.ts", "../../core/src/app/enums/app-enviroment.enum.ts", "../../core/src/app/enums/core-metadata-key.enum.ts", "../../core/src/app/enums/event-destination.enum.ts", "../../core/src/app/enums/execution-context-type.enum.ts", "../../core/src/app/enums/method-param-type.enum.ts", "../src/services/webview-rpc.service.ts", "../../core/src/errors/mango.error.ts", "../../core/src/errors/guard-cancel.error.ts", "../../core/src/errors/guard-invalid-return.error.ts", "../../core/src/errors/too-many-requests.error.ts", "../../core/src/errors/unknown.error.ts", "../src/index.ts"],
  "sourcesContent": ["import type { LoggerService } from '@ragemp-mango/core/interfaces';\n\nexport class WebViewLoggerService implements LoggerService {\n    public log(...args: unknown[]) {\n        console.log(`[🥭WebView][Log]`, ...args);\n    }\n\n    public error(...args: unknown[]) {\n        console.error(`[🥭WebView][Error]`, ...args);\n    }\n\n    public warn(...args: unknown[]) {\n        console.warn(`[🥭WebView][Warn]`, ...args);\n    }\n\n    public debug(...args: unknown[]) {\n        console.debug(`[🥭WebView][Debug]`, ...args);\n    }\n}\n", "import type { EventService, ScriptEventHandler } from '../interfaces';\n\nexport class WebViewEventService implements EventService {\n    private readonly $localHandlers: Map<string, Set<ScriptEventHandler>> = new Map();\n    private readonly $remoteHandlers: Map<string, Set<ScriptEventHandler>> = new Map();\n\n    public on<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ) {\n        const eventHandler: ScriptEventHandler = {\n            destroy: () => {\n                // @ts-ignore\n                eventHandler.valid = false;\n                const handlers = this.$localHandlers.get(eventName);\n                handlers?.delete(eventHandler);\n            },\n            eventName,\n            handler: callback,\n            local: true,\n            onlyOnce: false,\n            remote: false,\n            valid: true,\n        };\n\n        if (!this.$localHandlers.has(eventName)) {\n            this.$localHandlers.set(eventName, new Set());\n        }\n        this.$localHandlers.get(eventName)!.add(eventHandler);\n\n        return eventHandler;\n    }\n\n    public once<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ) {\n        const eventHandler = {\n            destroy: () => {\n                eventHandler.valid = false;\n                const handlers = this.$localHandlers.get(eventName);\n                handlers?.delete(eventHandler);\n            },\n            eventName,\n            handler: callback,\n            local: true,\n            onlyOnce: true,\n            remote: false,\n            valid: true,\n        };\n\n        if (!this.$localHandlers.has(eventName)) {\n            this.$localHandlers.set(eventName, new Set());\n        }\n        this.$localHandlers.get(eventName)!.add(eventHandler);\n\n        return <ScriptEventHandler>eventHandler;\n    }\n\n    public emit<E extends string>(eventName: E, body?: unknown) {\n        const listeners = this.$localHandlers.get(eventName);\n        listeners?.forEach((scriptEventHandler) => {\n            scriptEventHandler.handler(body);\n            if (!scriptEventHandler.onlyOnce) return;\n            scriptEventHandler.destroy();\n        });\n    }\n\n    public onPlayer<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ) {\n        const wrapper = (...args: any[]) => callback(args[0]);\n        const eventHandler: ScriptEventHandler = {\n            destroy: () => {\n                // @ts-ignore\n                eventHandler.valid = false;\n                const handlers = this.$remoteHandlers.get(eventName);\n                handlers?.delete(eventHandler);\n                // In RageMP CEF, we use mp.trigger to communicate\n                // Events are registered via window event listeners or mp.events\n            },\n            eventName,\n            handler: wrapper,\n            local: false,\n            onlyOnce: false,\n            remote: true,\n            valid: true,\n        };\n\n        // RageMP CEF uses window-level event registration\n        if (typeof (window as any).mp !== 'undefined') {\n            (window as any).mp.events.add(eventName, wrapper);\n        }\n\n        if (!this.$remoteHandlers.has(eventName)) {\n            this.$remoteHandlers.set(eventName, new Set());\n        }\n        this.$remoteHandlers.get(eventName)!.add(eventHandler);\n\n        return eventHandler;\n    }\n\n    public oncePlayer<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ) {\n        const wrapper = (...args: any[]) => {\n            callback(args[0]);\n            eventHandler.destroy();\n        };\n        const eventHandler: ScriptEventHandler = {\n            destroy: () => {\n                // @ts-ignore\n                eventHandler.valid = false;\n                const handlers = this.$remoteHandlers.get(eventName);\n                handlers?.delete(eventHandler);\n            },\n            eventName,\n            handler: wrapper,\n            local: false,\n            onlyOnce: true,\n            remote: true,\n            valid: true,\n        };\n\n        if (typeof (window as any).mp !== 'undefined') {\n            (window as any).mp.events.add(eventName, wrapper);\n        }\n\n        if (!this.$remoteHandlers.has(eventName)) {\n            this.$remoteHandlers.set(eventName, new Set());\n        }\n        this.$remoteHandlers.get(eventName)!.add(eventHandler);\n\n        return eventHandler;\n    }\n\n    public emitPlayer<E extends string>(eventName: E, body?: unknown) {\n        // RageMP CEF uses mp.trigger to send events to client\n        if (typeof (window as any).mp !== 'undefined') {\n            (window as any).mp.trigger(eventName, body);\n        }\n    }\n\n    public onServer<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ) {\n        return this.onPlayer(<string>`WEBVIEW::ON_SERVER_${eventName}`, <any>callback);\n    }\n\n    public onceServer<E extends string>(\n        eventName: E,\n        callback: (body: unknown) => void | Promise<void>,\n    ): ScriptEventHandler {\n        return this.oncePlayer(<string>`WEBVIEW::ON_SERVER_${eventName}`, <any>callback);\n    }\n\n    public emitServer<E extends string>(eventName: E, body?: unknown) {\n        // In RageMP, we emit to client which then forwards to server\n        if (typeof (window as any).mp !== 'undefined') {\n            (window as any).mp.trigger('WEBVIEW::EMIT_SERVER', {\n                eventName,\n                payload: body,\n            });\n        }\n    }\n}\n", "export enum ErrorMessage {\n    TooManyRequests = 'Too many requests.',\n\n    // Events\n    EventNameMustBeString = 'The event name must be a string.',\n    EventNameMustBeUnique = 'The event name must be unique.',\n    EventNotAllowedInClient = 'The event is not allowed in the client environment.',\n    EventNotAllowedInServer = 'The event is not allowed in the server environment.',\n    InvalidEventType = 'Invalid event type.',\n    InvalidInternalEventName = 'The name of the internal event is invalid.',\n    InvalidReturnInEvent = 'Cannot return a value from an event.',\n\n    // RPC\n    RPCNameMustBeString = 'The RPC name must be a string.',\n    RPCNameMustBeUnique = 'The RPC name must be unique.',\n    RPCNotAllowedInClient = 'The RPC is not allowed in the client environment.',\n    RPCNotAllowedInServer = 'The RPC is not allowed in the server environment.',\n    InvalidRPCType = 'Invalid RPC type.',\n    RPCHandlerAlreadyExists = 'The RPC handler already exists. Please provide a unique name for the RPC.',\n    RPCResponseAlreadySent = 'The RPC response has already been sent.',\n\n    // Error filters\n    InvalidErrorFilterDefinition = 'Invalid error filter. Error filters must be a class reference or an object with a catch method.',\n    ErrorAlreadyHandledByFilter = 'The error already points to a filter.',\n    ExceptionHandlingConflict = 'The same exception can only be caught once.',\n    AtLeastOneFilterRequired = 'At least one error filter must be provided.',\n    DuplicateErrorFilterDetected = 'Duplicate error filter found. Ensure that the same filter is not applied more than once.',\n\n    // WebView\n    WebViewNotFound = 'The WebView with the specified id does not exist.',\n    WebViewIdMustBeStringOrNumber = 'The WebView id must be a string or number.',\n\n    // Guard\n    InvalidGuardDefinition = 'Invalid guard. Guards must be a class reference or an object with a canActivate method.',\n    AtLeastOneGuardRequired = 'At least one guard must be provided.',\n\n    // Interceptor\n    InvalidInterceptorDefinition = 'Invalid interceptor. Interceptors must be a class reference or an object with an intercept method.',\n    AtLeastOneInterceptorRequired = 'At least one interceptor must be provided.',\n    InvalidInterceptorReturnValue = 'The interceptor must return a function.',\n\n    // Pipe\n    InvalidPipeDefinition = 'Invalid pipe. Pipes must be a class reference or an object with a transform method.',\n    AtLeastOnePipeRequired = 'At least one pipe must be provided.',\n\n    // App loading\n    AppAlreadyLoaded = 'App is already loaded. Please call the stop method before calling the start method.',\n    AppNotLoaded = 'App is not loaded. Please call the start method before calling the stop method.',\n\n    // Decorators\n    InvalidInjectionTokenSpecified = 'The specified injection token is invalid.',\n    InjectionTokenNotFound = 'The injection token could not be found.',\n    ParamKeyMustBeString = 'The param key must be a string.',\n    IndexKeyMustBeNumber = 'The index key must be a number.',\n    DuplicateDecoratorUsage = 'The same decorator can only be used once in the same class.',\n    InvalidControllerOptions = 'Invalid controller options found.',\n    InvalidInjectableOptions = 'Invalid injectable options found.',\n    InvalidModuleOptions = 'Invalid module options found.',\n    MultipleDecoratorsOnSingleParameterNotAllowed = 'Cannot apply multiple decorators to the same parameter.',\n\n    // Internal App\n    CircularDependencyDetected = 'Circular dependency detected.',\n    InvalidModuleDefinition = 'The module is invalid.',\n    InvalidExportDefinition = 'The export is invalid.',\n    InvalidProviderDefinition = 'The provider is invalid.',\n    InvalidParameterDecoratorUsage = 'Each parameter must have their its own decorator.',\n    ResponseDecoratorNotAllowedOnEvents = 'The @Response() decorator is not allowed on events.',\n    PlayerDecoratorNotAllowedOnClientEvents = 'The @Player() decorator is not allowed on client events.',\n\n    // Timers\n    TimerNameMustBeString = 'The timer name must be a string.',\n}\n", "export enum InjectableScope {\n    Request = 'request',\n    Transient = 'transient',\n    Singleton = 'singleton',\n}\n", "export enum RPCResultStatus {\n    Success = 1,\n    Timeout = 2,\n    HandlerNotFound = 3,\n    Unknown = 4,\n    CancelledByGuard = 5,\n    InvalidGuardReturn = 6,\n    TooManyRequests = 7,\n    PlayerDisconnected = 8,\n    PlayerNotFound = 9,\n}\n", "import { RPCResultStatus } from '../../enums';\nimport type { RPCResult } from '../../interfaces';\n\nexport const INTERNAL_APP_CONTAINER = 'INTERNAL_APP_CONTAINER';\nexport const GLOBAL_APP_CONTAINER = 'GLOBAL_APP_CONTAINER';\nexport const APP_ENVIROMENT = 'APP_ENVIROMENT';\n\nexport const GLOBAL_GUARDS = 'GLOBAL_GUARDS';\nexport const GLOBAL_INTERCEPTORS = 'GLOBAL_INTERCEPTORS';\nexport const GLOBAL_PIPES = 'GLOBAL_PIPES';\nexport const GLOBAL_ERROR_FILTERS = 'GLOBAL_ERROR_FILTERS';\n\nexport const PLUGINS = 'PLUGINS';\n\nexport const ENABLE_SHUTDOWN_HOOKS = 'ENABLE_SHUTDOWN_HOOKS';\nexport const CONTAINER_OPTIONS = 'CONTAINER_OPTIONS';\nexport const LOG_ERROR_STACKTRACE = 'LOG_ERROR_STACKTRACE';\n\nexport const MANGO_LOG_PREFIX = '🥭';\n\nexport const MANGO_REQUEST_FACTORY = 'MANGO_REQUEST_FACTORY';\nexport const MANGO_RESPONSE_FACTORY = 'MANGO_RESPONSE_FACTORY';\nexport const EXECUTION_CONTEXT_FACTORY = 'EXECUTION_CONTEXT_FACTORY';\n\nexport const MULTIPLAYER_SERVICE = 'MULTIPLAYER_SERVICE';\n\nexport const RPC_RESULT_TIMEOUT: RPCResult = {\n    success: false,\n    error: { message: 'RPC call timed out.' },\n    status: RPCResultStatus.Timeout,\n};\n\nexport const RPC_RESULT_HANDLER_NOT_FOUND: RPCResult = {\n    success: false,\n    error: { message: 'RPC handler not found.' },\n    status: RPCResultStatus.HandlerNotFound,\n};\n\nexport const RPC_RESULT_UNKNOWN: RPCResult = {\n    success: false,\n    error: { message: 'Unknown error.' },\n    status: RPCResultStatus.Unknown,\n};\n\nexport const RPC_RESULT_PLAYER_DISCONNECTED: RPCResult = {\n    success: false,\n    error: { message: 'Player disconnected.' },\n    status: RPCResultStatus.PlayerDisconnected,\n};\n\nexport const RPC_RESULT_PLAYER_NOT_FOUND: RPCResult = {\n    success: false,\n    error: { message: 'Player not found.' },\n    status: RPCResultStatus.PlayerNotFound,\n};\n", "var __defProp = Object.defineProperty;\nvar __name = (target, value)=>__defProp(target, \"name\", {\n        value,\n        configurable: true\n    });\nexport { __name }; //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9", "export function generateRandomId() {\n    return Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);\n}\n", "export const isUndefined = (obj: any): obj is undefined => typeof obj === 'undefined';\nexport const isObject = (fn: any): fn is object => !isNil(fn) && typeof fn === 'object';\nexport const isFunction = (val: any): val is Function => typeof val === 'function';\nexport const isString = (val: any): val is string => typeof val === 'string';\nexport const isNumber = (val: any): val is number => typeof val === 'number';\nexport const isConstructor = (val: any): boolean => val === 'constructor';\nexport const isNil = (val: any): val is null | undefined => isUndefined(val) || val === null;\nexport const isEmpty = (array: any): boolean => !(array && array.length > 0);\nexport const isSymbol = (val: any): val is symbol => typeof val === 'symbol';\nexport const isAsyncFunction = (val: any): boolean => isFunction(val) && val.constructor.name === 'AsyncFunction';\nexport const isBoolean = (val: any): val is boolean => typeof val === 'boolean';\nexport const isPromise = <T = any>(val: any): val is Promise<T> => val instanceof Promise;\n", "export enum AppEnviroment {\n    Client,\n    Server,\n}\n", "export enum CoreMetadataKey {\n    // General\n    Injectable = 'mango:injectable',\n    Inject = 'mango:inject',\n    Module = 'mango:module',\n    GlobalModule = 'mango:global-module',\n    Controller = 'mango:controller-options',\n    // Events & RPC\n    ControllerEvents = 'mango:controller-events',\n    ControllerRPCs = 'mango:controller-rpcs',\n    ControllerParams = 'mango:controller-rpc-params',\n    // Pipeline\n    Guards = 'mango:guards',\n    Interceptors = 'mango:interceptors',\n    Pipes = 'mango:pipes',\n    // Error\n    Catch = 'mango:catch',\n    ErrorFilters = 'mango:error-filters',\n    //\n    Timers = 'mango:timers',\n}\n", "export enum EventDestination {\n    Server = 'server',\n    Client = 'client',\n    WebView = 'webview',\n}\n", "export enum ExecutionContextType {\n    Event = 'event',\n    RPC = 'rpc',\n}\n", "export enum MethodParamType {\n    Body = 'body',\n    Custom = 'custom',\n    Param = 'param',\n    Player = 'player',\n    Request = 'request',\n    Response = 'response',\n    Index = 'index',\n}\n", "import { type RPCCallOptions, type RPCResult, type ScriptRPCHandler } from '@ragemp-mango/core/interfaces';\nimport { RPC_RESULT_HANDLER_NOT_FOUND, RPC_RESULT_TIMEOUT } from '@ragemp-mango/core/app/constants';\nimport type { EventService, RPCService } from '../interfaces';\nimport type { WebViewEventService } from './webview-event.service';\nimport type { WebViewLoggerService } from './webview-logger.service';\nimport { generateRandomId, isNil } from '@ragemp-mango/core/utils';\nimport { ErrorMessage, RPCResultStatus } from '@ragemp-mango/core/enums';\nimport { EventDestination } from '@ragemp-mango/core/app/enums';\nimport type { RPCPayload } from '@ragemp-mango/core/app/interfaces';\n\nexport class WebViewRPCService implements RPCService {\n    private readonly $TIMEOUT = 2000;\n    public readonly $localHandlers = new Map<string, ScriptRPCHandler>();\n    public readonly $clientHandlers = new Map<string, ScriptRPCHandler>();\n    public readonly $serverHandlers = new Map<string, ScriptRPCHandler>();\n\n    public constructor(private readonly $eventService: WebViewEventService, private readonly $loggerService: WebViewLoggerService) {}\n\n    public async call<E extends string>(\n        rpcName: E,\n        body?: unknown,\n        options: RPCCallOptions = { timeout: this.$TIMEOUT },\n    ): Promise<RPCResult> {\n        return new Promise(async (resolve) => {\n            const rpcHandler = this.$localHandlers.get(rpcName);\n            if (isNil(rpcHandler)) {\n                resolve(RPC_RESULT_HANDLER_NOT_FOUND);\n                return;\n            }\n\n            const timeoutId = setTimeout(() => {\n                resolve(RPC_RESULT_TIMEOUT);\n            }, options.timeout);\n\n            const result = await rpcHandler.handler(body);\n            clearTimeout(timeoutId);\n            resolve({ success: true, status: RPCResultStatus.Success, body: result, error: undefined });\n        });\n    }\n\n    public onRequest<E extends string>(\n        rpcName: E,\n        handler: (body: unknown) => unknown | Promise<unknown>,\n    ): ScriptRPCHandler {\n        if (this.$localHandlers.has(rpcName)) {\n            this.$loggerService.error('An error occurred while registering a RPC handler.');\n            throw new Error(ErrorMessage.RPCHandlerAlreadyExists);\n        }\n        const rpcHandler: ScriptRPCHandler = {\n            destroy: () => {\n                // @ts-ignore\n                rpcHandler.valid = false;\n                this.$localHandlers.delete(rpcName);\n            },\n            rpcName,\n            handler,\n            valid: true,\n        };\n        this.$localHandlers.set(rpcName, rpcHandler);\n        return rpcHandler;\n    }\n\n    public callServer<E extends string>(\n        rpcName: E,\n        body?: unknown,\n        options: RPCCallOptions = { timeout: this.$TIMEOUT },\n    ): Promise<RPCResult> {\n        return this.$handleCall(rpcName, EventDestination.Server, options, body);\n    }\n\n    public onServerRequest<E extends string>(\n        rpcName: E,\n        handler: (body: unknown) => unknown | Promise<unknown>,\n    ): ScriptRPCHandler {\n        if (this.$serverHandlers.has(rpcName)) {\n            this.$loggerService.error('An error occurred while registering a RPC handler.');\n            throw new Error(ErrorMessage.RPCHandlerAlreadyExists);\n        }\n        const rpcHandler: ScriptRPCHandler = {\n            destroy: () => {\n                // @ts-ignore\n                rpcHandler.valid = false;\n                this.$serverHandlers.delete(rpcName);\n            },\n            rpcName,\n            handler,\n            valid: true,\n        };\n        this.$serverHandlers.set(rpcName, rpcHandler);\n        return rpcHandler;\n    }\n\n    public callPlayer<E extends string>(\n        rpcName: E,\n        body?: unknown,\n        options: RPCCallOptions = { timeout: this.$TIMEOUT },\n    ): Promise<RPCResult> {\n        return this.$handleCall(rpcName, EventDestination.Client, options, body);\n    }\n\n    public onPlayerRequest<E extends string>(\n        rpcName: E,\n        handler: (body: unknown) => unknown | Promise<unknown>,\n    ): ScriptRPCHandler {\n        if (this.$clientHandlers.has(rpcName)) {\n            this.$loggerService.error('An error occurred while registering a RPC listener.');\n            throw new Error(ErrorMessage.RPCHandlerAlreadyExists);\n        }\n        const rpcHandler: ScriptRPCHandler = {\n            destroy: () => {\n                // @ts-ignore\n                rpcHandler.valid = false;\n                this.$clientHandlers.delete(rpcName);\n            },\n            rpcName,\n            handler,\n            valid: true,\n        };\n        this.$clientHandlers.set(rpcName, rpcHandler);\n        return rpcHandler;\n    }\n\n    private async $handleCall<TResult>(\n        rpcName: string,\n        destination: EventDestination, // 'client' | 'server',\n        options?: Partial<RPCCallOptions>,\n        body?: unknown,\n    ) {\n        return new Promise<RPCResult<TResult>>((resolve) => {\n            const callId = generateRandomId();\n            let timeoutId: number;\n\n            const onceHandle = (body: unknown) => {\n                clearTimeout(timeoutId);\n                resolve(<RPCResult<TResult>>body);\n            };\n            const scriptEventHandler =\n                destination === EventDestination.Server\n                    ? this.$eventService.onceServer(`RPC::RETURN_FROM_SERVER_${callId}`, onceHandle)\n                    : this.$eventService.oncePlayer(`RPC::RETURN_FROM_CLIENT_${callId}`, onceHandle);\n\n            const payload: RPCPayload = {\n                source: EventDestination.WebView,\n                destination,\n                id: callId,\n                rpcName,\n                body,\n            };\n            destination === EventDestination.Server\n                ? (<EventService>this.$eventService).emitPlayer('RPC::CALL_SERVER', payload)\n                : (<EventService>this.$eventService).emitPlayer('RPC::CALL_CLIENT', payload);\n\n            timeoutId = setTimeout(() => {\n                scriptEventHandler.destroy();\n                resolve(<RPCResult<TResult>>RPC_RESULT_TIMEOUT);\n            }, options?.timeout ?? this.$TIMEOUT);\n        });\n    }\n}\n", "import { RPCResultStatus } from '../enums';\n\nexport class MangoError<TDetails = unknown> extends Error {\n    public status: number = RPCResultStatus.Unknown;\n    public details: TDetails | undefined;\n\n    public constructor(message: string, status?: number, details?: TDetails) {\n        super(message);\n        this.status = status ?? RPCResultStatus.Unknown;\n        this.details = details;\n    }\n}\n", "import { RPCResultStatus } from '../enums';\nimport { MangoError } from './mango.error';\n\nexport class GuardCancelError extends MangoError {\n    public constructor() {\n        super('Process cancelled by the guard.', RPCResultStatus.CancelledByGuard);\n    }\n}\n", "import { RPCResultStatus } from '../enums';\nimport { MangoError } from './mango.error';\n\nexport class GuardInvalidReturnError extends MangoError {\n    public constructor() {\n        super('Guard returned an invalid value. Expected boolean.', RPCResultStatus.InvalidGuardReturn);\n    }\n}\n", "import { RPCResultStatus } from '../enums';\nimport { MangoError } from './mango.error';\n\nexport class TooManyRequests extends MangoError {\n    public constructor(message = 'Too many requests.') {\n        super(message, RPCResultStatus.TooManyRequests);\n    }\n}\n", "import { RPCResultStatus } from '../enums';\nimport { MangoError } from './mango.error';\n\nexport class UnknownError extends MangoError {\n    public constructor() {\n        super('Unknown error.', RPCResultStatus.Unknown);\n    }\n}\n", "import { WebViewEventService, WebViewLoggerService, WebViewRPCService } from './services';\nimport { isNil } from '@ragemp-mango/core/utils';\nimport { RPC_RESULT_HANDLER_NOT_FOUND, RPC_RESULT_UNKNOWN } from '@ragemp-mango/core/app/constants';\nimport { RPCResultStatus } from '@ragemp-mango/core/enums';\nimport type { LoggerService, RPCResult } from '@ragemp-mango/core/interfaces';\nimport { MangoError } from '@ragemp-mango/core/errors';\nimport type { EventService, RPCService } from './interfaces';\n\nexport function initMango() {\n    if (!isNil(window.mango)) {\n        return window.mango;\n    }\n\n    const event = new WebViewEventService();\n    const logger = new WebViewLoggerService();\n    const rpc = new WebViewRPCService(event, logger);\n\n    (<EventService>event).onServer('RPC::CALL_WEBVIEW', async (body) => {\n        const id = body.id;\n        const name = body.rpcName;\n        const payload = body.body;\n\n        const rpcHandler = rpc.$serverHandlers.get(name);\n        if (!rpcHandler) {\n            event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_HANDLER_NOT_FOUND);\n            return;\n        }\n\n        try {\n            const result = await rpcHandler.handler(payload);\n            const rpcResult: RPCResult = {\n                success: true,\n                status: RPCResultStatus.Success,\n                body: result,\n            };\n            event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);\n        } catch (error) {\n            if (error instanceof MangoError) {\n                const rpcResult: RPCResult = {\n                    success: false,\n                    status: error.status,\n                    error: { message: error.message, details: error.details },\n                };\n                event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);\n                return;\n            }\n\n            event.emitServer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_UNKNOWN);\n        }\n    });\n    (<EventService>event).onPlayer('RPC::CALL_WEBVIEW', async (body) => {\n        const id = body.id;\n        const name = body.rpcName;\n        const payload = body.body;\n\n        const rpcHandler = rpc.$clientHandlers.get(name);\n        if (isNil(rpcHandler)) {\n            event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_HANDLER_NOT_FOUND);\n            return;\n        }\n\n        try {\n            const result = await rpcHandler.handler(payload);\n            const rpcResult: RPCResult = {\n                success: true,\n                status: RPCResultStatus.Success,\n                body: result,\n            };\n            event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, rpcResult);\n        } catch (error) {\n            event.emitPlayer(`RPC::RETURN_FROM_WEBVIEW_${id}`, RPC_RESULT_UNKNOWN);\n        }\n    });\n\n    const mango = { event, rpc, logger };\n\n    window.mango = mango;\n\n    logger.log('WebView initialized');\n\n    return mango;\n}\n\ndeclare global {\n    export interface Window {\n        mango: {\n            event: EventService;\n            rpc: RPCService;\n            logger: LoggerService;\n        };\n    }\n}\n\nimport './extension.d.ts';\n"],
  "mappings": ";;;;AAEO,IAAMA,uBAAN,MAAMA;EAAb,OAAaA;;;EACFC,OAAOC,MAAiB;AAC3BC,YAAQF,IAAI,2BAAkB,GAAKC,IAAAA;EACvC;EAEOE,SAASF,MAAiB;AAC7BC,YAAQC,MAAM,6BAAoB,GAAKF,IAAAA;EAC3C;EAEOG,QAAQH,MAAiB;AAC5BC,YAAQE,KAAK,4BAAmB,GAAKH,IAAAA;EACzC;EAEOI,SAASJ,MAAiB;AAC7BC,YAAQG,MAAM,6BAAoB,GAAKJ,IAAAA;EAC3C;AACJ;;;AChBO,IAAMK,sBAAN,MAAMA;EAAb,OAAaA;;;EACQC,iBAAuD,oBAAIC,IAAAA;EAC3DC,kBAAwD,oBAAID,IAAAA;EAEtEE,GACHC,WACAC,UACF;AACE,UAAMC,eAAmC;MACrCC,SAAS,6BAAA;AAELD,qBAAaE,QAAQ;AACrB,cAAMC,WAAW,KAAKT,eAAeU,IAAIN,SAAAA;AACzCK,kBAAUE,OAAOL,YAAAA;MACrB,GALS;MAMTF;MACAQ,SAASP;MACTQ,OAAO;MACPC,UAAU;MACVC,QAAQ;MACRP,OAAO;IACX;AAEA,QAAI,CAAC,KAAKR,eAAegB,IAAIZ,SAAAA,GAAY;AACrC,WAAKJ,eAAeiB,IAAIb,WAAW,oBAAIc,IAAAA,CAAAA;IAC3C;AACA,SAAKlB,eAAeU,IAAIN,SAAAA,EAAYe,IAAIb,YAAAA;AAExC,WAAOA;EACX;EAEOc,KACHhB,WACAC,UACF;AACE,UAAMC,eAAe;MACjBC,SAAS,6BAAA;AACLD,qBAAaE,QAAQ;AACrB,cAAMC,WAAW,KAAKT,eAAeU,IAAIN,SAAAA;AACzCK,kBAAUE,OAAOL,YAAAA;MACrB,GAJS;MAKTF;MACAQ,SAASP;MACTQ,OAAO;MACPC,UAAU;MACVC,QAAQ;MACRP,OAAO;IACX;AAEA,QAAI,CAAC,KAAKR,eAAegB,IAAIZ,SAAAA,GAAY;AACrC,WAAKJ,eAAeiB,IAAIb,WAAW,oBAAIc,IAAAA,CAAAA;IAC3C;AACA,SAAKlB,eAAeU,IAAIN,SAAAA,EAAYe,IAAIb,YAAAA;AAExC,WAA2BA;EAC/B;EAEOe,KAAuBjB,WAAckB,MAAgB;AACxD,UAAMC,YAAY,KAAKvB,eAAeU,IAAIN,SAAAA;AAC1CmB,eAAWC,QAAQ,CAACC,uBAAAA;AAChBA,yBAAmBb,QAAQU,IAAAA;AAC3B,UAAI,CAACG,mBAAmBX,SAAU;AAClCW,yBAAmBlB,QAAO;IAC9B,CAAA;EACJ;EAEOmB,SACHtB,WACAC,UACF;AACE,UAAMsB,UAAU,2BAAIC,SAAgBvB,SAASuB,KAAK,CAAA,CAAE,GAApC;AAChB,UAAMtB,eAAmC;MACrCC,SAAS,6BAAA;AAELD,qBAAaE,QAAQ;AACrB,cAAMC,WAAW,KAAKP,gBAAgBQ,IAAIN,SAAAA;AAC1CK,kBAAUE,OAAOL,YAAAA;MAGrB,GAPS;MAQTF;MACAQ,SAASe;MACTd,OAAO;MACPC,UAAU;MACVC,QAAQ;MACRP,OAAO;IACX;AAGA,QAAI,OAAQqB,OAAeC,OAAO,aAAa;AAC1CD,aAAeC,GAAGC,OAAOZ,IAAIf,WAAWuB,OAAAA;IAC7C;AAEA,QAAI,CAAC,KAAKzB,gBAAgBc,IAAIZ,SAAAA,GAAY;AACtC,WAAKF,gBAAgBe,IAAIb,WAAW,oBAAIc,IAAAA,CAAAA;IAC5C;AACA,SAAKhB,gBAAgBQ,IAAIN,SAAAA,EAAYe,IAAIb,YAAAA;AAEzC,WAAOA;EACX;EAEO0B,WACH5B,WACAC,UACF;AACE,UAAMsB,UAAU,2BAAIC,SAAAA;AAChBvB,eAASuB,KAAK,CAAA,CAAE;AAChBtB,mBAAaC,QAAO;IACxB,GAHgB;AAIhB,UAAMD,eAAmC;MACrCC,SAAS,6BAAA;AAELD,qBAAaE,QAAQ;AACrB,cAAMC,WAAW,KAAKP,gBAAgBQ,IAAIN,SAAAA;AAC1CK,kBAAUE,OAAOL,YAAAA;MACrB,GALS;MAMTF;MACAQ,SAASe;MACTd,OAAO;MACPC,UAAU;MACVC,QAAQ;MACRP,OAAO;IACX;AAEA,QAAI,OAAQqB,OAAeC,OAAO,aAAa;AAC1CD,aAAeC,GAAGC,OAAOZ,IAAIf,WAAWuB,OAAAA;IAC7C;AAEA,QAAI,CAAC,KAAKzB,gBAAgBc,IAAIZ,SAAAA,GAAY;AACtC,WAAKF,gBAAgBe,IAAIb,WAAW,oBAAIc,IAAAA,CAAAA;IAC5C;AACA,SAAKhB,gBAAgBQ,IAAIN,SAAAA,EAAYe,IAAIb,YAAAA;AAEzC,WAAOA;EACX;EAEO2B,WAA6B7B,WAAckB,MAAgB;AAE9D,QAAI,OAAQO,OAAeC,OAAO,aAAa;AAC1CD,aAAeC,GAAGI,QAAQ9B,WAAWkB,IAAAA;IAC1C;EACJ;EAEOa,SACH/B,WACAC,UACF;AACE,WAAO,KAAKqB,SAAiB,sBAAsBtB,SAAAA,IAAkBC,QAAAA;EACzE;EAEO+B,WACHhC,WACAC,UACkB;AAClB,WAAO,KAAK2B,WAAmB,sBAAsB5B,SAAAA,IAAkBC,QAAAA;EAC3E;EAEOgC,WAA6BjC,WAAckB,MAAgB;AAE9D,QAAI,OAAQO,OAAeC,OAAO,aAAa;AAC1CD,aAAeC,GAAGI,QAAQ,wBAAwB;QAC/C9B;QACAkC,SAAShB;MACb,CAAA;IACJ;EACJ;AACJ;;;ACxKO,IAAKiB,eAAAA,0BAAAA,eAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;SAAAA;;AEAL,IAAKC,kBAAAA,0BAAAA,kBAAAA;;;;;;;;;;SAAAA;;;;AC0BL,IAAMC,qBAAgC;EACzCC,SAAS;EACTC,OAAO;IAAEC,SAAS;EAAsB;EACxCC,QAAQC,gBAAgBC;AAC5B;AAEO,IAAMC,+BAA0C;EACnDN,SAAS;EACTC,OAAO;IAAEC,SAAS;EAAyB;EAC3CC,QAAQC,gBAAgBG;AAC5B;AAEO,IAAMC,qBAAgC;EACzCR,SAAS;EACTC,OAAO;IAAEC,SAAS;EAAiB;EACnCC,QAAQC,gBAAgBK;AAC5B;AAEO,IAAMC,iCAA4C;EACrDV,SAAS;EACTC,OAAO;IAAEC,SAAS;EAAuB;EACzCC,QAAQC,gBAAgBO;AAC5B;AAEO,IAAMC,8BAAyC;EAClDZ,SAAS;EACTC,OAAO;IAAEC,SAAS;EAAoB;EACtCC,QAAQC,gBAAgBS;AAC5B;;;ACtDA,IAAIC,aAAY,OAAO;AACvB,IAAIC,UAAS,wBAAC,QAAQ,UAAQD,WAAU,QAAQ,QAAQ;AAAA,EAChD;AAAA,EACA,cAAc;AAClB,CAAC,GAHQ;;;ACDN,SAASE,mBAAAA;AACZ,SAAOC,KAAKC,OAAM,EAAGC,SAAS,EAAA,EAAIC,UAAU,GAAG,EAAA,IAAMH,KAAKC,OAAM,EAAGC,SAAS,EAAA,EAAIC,UAAU,GAAG,EAAA;AACjG;AAFgBJ;AAAAA,QAAAA,kBAAAA,kBAAAA;ACAT,IAAMK,cAAc,gBAAAC,QAAA,CAACC,QAA+B,OAAOA,QAAQ,aAA/C,aAAA;AAMpB,IAAMC,QAAQ,gBAAAC,QAAA,CAACC,QAAsCC,YAAYD,GAAAA,KAAQA,QAAQ,MAAnE,OAAA;;;AGNd,IAAKE,mBAAAA,0BAAAA,mBAAAA;;;;SAAAA;;;;AGUL,IAAMC,oBAAN,MAAMA;EATb,OASaA;;;;;EACQC,WAAW;EACZC,iBAAiB,oBAAIC,IAAAA;EACrBC,kBAAkB,oBAAID,IAAAA;EACtBE,kBAAkB,oBAAIF,IAAAA;EAEtC,YAAoCG,eAAqDC,gBAAsC;SAA3FD,gBAAAA;SAAqDC,iBAAAA;EAAuC;EAEhI,MAAaC,KACTC,SACAC,MACAC,UAA0B;IAAEC,SAAS,KAAKX;EAAS,GACjC;AAClB,WAAO,IAAIY,QAAQ,OAAOC,YAAAA;AACtB,YAAMC,aAAa,KAAKb,eAAec,IAAIP,OAAAA;AAC3C,UAAIQ,MAAMF,UAAAA,GAAa;AACnBD,gBAAQI,4BAAAA;AACR;MACJ;AAEA,YAAMC,YAAYC,WAAW,MAAA;AACzBN,gBAAQO,kBAAAA;MACZ,GAAGV,QAAQC,OAAO;AAElB,YAAMU,SAAS,MAAMP,WAAWQ,QAAQb,IAAAA;AACxCc,mBAAaL,SAAAA;AACbL,cAAQ;QAAEW,SAAS;QAAMC,QAAQC,gBAAgBC;QAASlB,MAAMY;QAAQO,OAAOC;MAAU,CAAA;IAC7F,CAAA;EACJ;EAEOC,UACHtB,SACAc,SACgB;AAChB,QAAI,KAAKrB,eAAe8B,IAAIvB,OAAAA,GAAU;AAClC,WAAKF,eAAesB,MAAM,oDAAA;AAC1B,YAAM,IAAII,MAAMC,aAAaC,uBAAuB;IACxD;AACA,UAAMpB,aAA+B;MACjCqB,SAAS,6BAAA;AAELrB,mBAAWsB,QAAQ;AACnB,aAAKnC,eAAeoC,OAAO7B,OAAAA;MAC/B,GAJS;MAKTA;MACAc;MACAc,OAAO;IACX;AACA,SAAKnC,eAAeqC,IAAI9B,SAASM,UAAAA;AACjC,WAAOA;EACX;EAEOyB,WACH/B,SACAC,MACAC,UAA0B;IAAEC,SAAS,KAAKX;EAAS,GACjC;AAClB,WAAO,KAAKwC,YAAYhC,SAASiC,iBAAiBC,QAAQhC,SAASD,IAAAA;EACvE;EAEOkC,gBACHnC,SACAc,SACgB;AAChB,QAAI,KAAKlB,gBAAgB2B,IAAIvB,OAAAA,GAAU;AACnC,WAAKF,eAAesB,MAAM,oDAAA;AAC1B,YAAM,IAAII,MAAMC,aAAaC,uBAAuB;IACxD;AACA,UAAMpB,aAA+B;MACjCqB,SAAS,6BAAA;AAELrB,mBAAWsB,QAAQ;AACnB,aAAKhC,gBAAgBiC,OAAO7B,OAAAA;MAChC,GAJS;MAKTA;MACAc;MACAc,OAAO;IACX;AACA,SAAKhC,gBAAgBkC,IAAI9B,SAASM,UAAAA;AAClC,WAAOA;EACX;EAEO8B,WACHpC,SACAC,MACAC,UAA0B;IAAEC,SAAS,KAAKX;EAAS,GACjC;AAClB,WAAO,KAAKwC,YAAYhC,SAASiC,iBAAiBI,QAAQnC,SAASD,IAAAA;EACvE;EAEOqC,gBACHtC,SACAc,SACgB;AAChB,QAAI,KAAKnB,gBAAgB4B,IAAIvB,OAAAA,GAAU;AACnC,WAAKF,eAAesB,MAAM,qDAAA;AAC1B,YAAM,IAAII,MAAMC,aAAaC,uBAAuB;IACxD;AACA,UAAMpB,aAA+B;MACjCqB,SAAS,6BAAA;AAELrB,mBAAWsB,QAAQ;AACnB,aAAKjC,gBAAgBkC,OAAO7B,OAAAA;MAChC,GAJS;MAKTA;MACAc;MACAc,OAAO;IACX;AACA,SAAKjC,gBAAgBmC,IAAI9B,SAASM,UAAAA;AAClC,WAAOA;EACX;EAEA,MAAc0B,YACVhC,SACAuC,aACArC,SACAD,MACF;AACE,WAAO,IAAIG,QAA4B,CAACC,YAAAA;AACpC,YAAMmC,SAASC,iBAAAA;AACf,UAAI/B;AAEJ,YAAMgC,aAAa,wBAACzC,UAAAA;AAChBc,qBAAaL,SAAAA;AACbL,gBAA4BJ,KAAAA;MAChC,GAHmB;AAInB,YAAM0C,qBACFJ,gBAAgBN,iBAAiBC,SAC3B,KAAKrC,cAAc+C,WAAW,2BAA2BJ,MAAAA,IAAUE,UAAAA,IACnE,KAAK7C,cAAcgD,WAAW,2BAA2BL,MAAAA,IAAUE,UAAAA;AAE7E,YAAMI,UAAsB;QACxBC,QAAQd,iBAAiBe;QACzBT;QACAU,IAAIT;QACJxC;QACAC;MACJ;AACAsC,sBAAgBN,iBAAiBC,SACZ,KAAKrC,cAAeqD,WAAW,oBAAoBJ,OAAAA,IACnD,KAAKjD,cAAeqD,WAAW,oBAAoBJ,OAAAA;AAExEpC,kBAAYC,WAAW,MAAA;AACnBgC,2BAAmBhB,QAAO;AAC1BtB,gBAA4BO,kBAAAA;MAChC,GAAGV,SAASC,WAAW,KAAKX,QAAQ;IACxC,CAAA;EACJ;AACJ;;;AC5JO,IAAM2D,aAAN,cAA6CC,MAAAA;SAAAA;;;EAFpD,OAEoDA;;;EACzCC,SAAiBC,gBAAgBC;EACjCC;EAEP,YAAmBC,SAAiBJ,QAAiBG,SAAoB;AACrE,UAAMC,OAAAA;AACN,SAAKJ,SAASA,UAAUC,gBAAgBC;AACxC,SAAKC,UAAUA;EACnB;AACJ;ACRO,IAAME,mBAAN,cAA+BP,WAAAA;SAAAA;;;EAHtC,OAGsCA;;;EAClC,cAAqB;AACjB,UAAM,mCAAmCG,gBAAgBK,gBAAgB;EAC7E;AACJ;ACJO,IAAMC,0BAAN,cAAsCT,WAAAA;SAAAA;;;EAH7C,OAG6CA;;;EACzC,cAAqB;AACjB,UAAM,sDAAsDG,gBAAgBO,kBAAkB;EAClG;AACJ;ACJO,IAAMC,kBAAN,cAA8BX,WAAAA;SAAAA;;;EAHrC,OAGqCA;;;EACjC,YAAmBM,UAAU,sBAAsB;AAC/C,UAAMA,SAASH,gBAAgBQ,eAAe;EAClD;AACJ;ACJO,IAAMC,eAAN,cAA2BZ,WAAAA;SAAAA;;;EAHlC,OAGkCA;;;EAC9B,cAAqB;AACjB,UAAM,kBAAkBG,gBAAgBC,OAAO;EACnD;AACJ;;;ACCO,SAASS,YAAAA;AACZ,MAAI,CAACC,MAAMC,OAAOC,KAAK,GAAG;AACtB,WAAOD,OAAOC;EAClB;AAEA,QAAMC,QAAQ,IAAIC,oBAAAA;AAClB,QAAMC,SAAS,IAAIC,qBAAAA;AACnB,QAAMC,MAAM,IAAIC,kBAAkBL,OAAOE,MAAAA;AAE1BF,QAAOM,SAAS,qBAAqB,OAAOC,SAAAA;AACvD,UAAMC,KAAKD,KAAKC;AAChB,UAAMC,OAAOF,KAAKG;AAClB,UAAMC,UAAUJ,KAAKA;AAErB,UAAMK,aAAaR,IAAIS,gBAAgBC,IAAIL,IAAAA;AAC3C,QAAI,CAACG,YAAY;AACbZ,YAAMe,WAAW,4BAA4BP,EAAAA,IAAMQ,4BAAAA;AACnD;IACJ;AAEA,QAAI;AACA,YAAMC,SAAS,MAAML,WAAWM,QAAQP,OAAAA;AACxC,YAAMQ,YAAuB;QACzBC,SAAS;QACTC,QAAQC,gBAAgBC;QACxBhB,MAAMU;MACV;AACAjB,YAAMe,WAAW,4BAA4BP,EAAAA,IAAMW,SAAAA;IACvD,SAASK,OAAO;AACZ,UAAIA,iBAAiBC,YAAY;AAC7B,cAAMN,YAAuB;UACzBC,SAAS;UACTC,QAAQG,MAAMH;UACdG,OAAO;YAAEE,SAASF,MAAME;YAASC,SAASH,MAAMG;UAAQ;QAC5D;AACA3B,cAAMe,WAAW,4BAA4BP,EAAAA,IAAMW,SAAAA;AACnD;MACJ;AAEAnB,YAAMe,WAAW,4BAA4BP,EAAAA,IAAMoB,kBAAAA;IACvD;EACJ,CAAA;AACe5B,QAAO6B,SAAS,qBAAqB,OAAOtB,SAAAA;AACvD,UAAMC,KAAKD,KAAKC;AAChB,UAAMC,OAAOF,KAAKG;AAClB,UAAMC,UAAUJ,KAAKA;AAErB,UAAMK,aAAaR,IAAI0B,gBAAgBhB,IAAIL,IAAAA;AAC3C,QAAIZ,MAAMe,UAAAA,GAAa;AACnBZ,YAAM+B,WAAW,4BAA4BvB,EAAAA,IAAMQ,4BAAAA;AACnD;IACJ;AAEA,QAAI;AACA,YAAMC,SAAS,MAAML,WAAWM,QAAQP,OAAAA;AACxC,YAAMQ,YAAuB;QACzBC,SAAS;QACTC,QAAQC,gBAAgBC;QACxBhB,MAAMU;MACV;AACAjB,YAAM+B,WAAW,4BAA4BvB,EAAAA,IAAMW,SAAAA;IACvD,SAASK,OAAO;AACZxB,YAAM+B,WAAW,4BAA4BvB,EAAAA,IAAMoB,kBAAAA;IACvD;EACJ,CAAA;AAEA,QAAM7B,QAAQ;IAAEC;IAAOI;IAAKF;EAAO;AAEnCJ,SAAOC,QAAQA;AAEfG,SAAO8B,IAAI,qBAAA;AAEX,SAAOjC;AACX;AAzEgBH;",
  "names": ["WebViewLoggerService", "log", "args", "console", "error", "warn", "debug", "WebViewEventService", "$localHandlers", "Map", "$remoteHandlers", "on", "eventName", "callback", "eventHandler", "destroy", "valid", "handlers", "get", "delete", "handler", "local", "onlyOnce", "remote", "has", "set", "Set", "add", "once", "emit", "body", "listeners", "forEach", "scriptEventHandler", "onPlayer", "wrapper", "args", "window", "mp", "events", "oncePlayer", "emitPlayer", "trigger", "onServer", "onceServer", "emitServer", "payload", "ErrorMessage", "RPCResultStatus", "RPC_RESULT_TIMEOUT", "success", "error", "message", "status", "RPCResultStatus", "Timeout", "RPC_RESULT_HANDLER_NOT_FOUND", "HandlerNotFound", "RPC_RESULT_UNKNOWN", "Unknown", "RPC_RESULT_PLAYER_DISCONNECTED", "PlayerDisconnected", "RPC_RESULT_PLAYER_NOT_FOUND", "PlayerNotFound", "__defProp", "__name", "generateRandomId", "Math", "random", "toString", "substring", "isUndefined", "__name", "obj", "isNil", "__name", "val", "isUndefined", "EventDestination", "WebViewRPCService", "$TIMEOUT", "$localHandlers", "Map", "$clientHandlers", "$serverHandlers", "$eventService", "$loggerService", "call", "rpcName", "body", "options", "timeout", "Promise", "resolve", "rpcHandler", "get", "isNil", "RPC_RESULT_HANDLER_NOT_FOUND", "timeoutId", "setTimeout", "RPC_RESULT_TIMEOUT", "result", "handler", "clearTimeout", "success", "status", "RPCResultStatus", "Success", "error", "undefined", "onRequest", "has", "Error", "ErrorMessage", "RPCHandlerAlreadyExists", "destroy", "valid", "delete", "set", "callServer", "$handleCall", "EventDestination", "Server", "onServerRequest", "callPlayer", "Client", "onPlayerRequest", "destination", "callId", "generateRandomId", "onceHandle", "scriptEventHandler", "onceServer", "oncePlayer", "payload", "source", "WebView", "id", "emitPlayer", "MangoError", "Error", "status", "RPCResultStatus", "Unknown", "details", "message", "GuardCancelError", "CancelledByGuard", "GuardInvalidReturnError", "InvalidGuardReturn", "TooManyRequests", "UnknownError", "initMango", "isNil", "window", "mango", "event", "WebViewEventService", "logger", "WebViewLoggerService", "rpc", "WebViewRPCService", "onServer", "body", "id", "name", "rpcName", "payload", "rpcHandler", "$serverHandlers", "get", "emitServer", "RPC_RESULT_HANDLER_NOT_FOUND", "result", "handler", "rpcResult", "success", "status", "RPCResultStatus", "Success", "error", "MangoError", "message", "details", "RPC_RESULT_UNKNOWN", "onPlayer", "$clientHandlers", "emitPlayer", "log"]
}

package/package.json ADDED
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "@ragemp-mango/webview",
3
+ "version": "2.0.6-beta.0",
4
+ "homepage": "https://github.com/kkwlkk/ragemp-mango",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "https://github.com/kkwlkk/ragemp-mango",
8
+ "directory": "packages/webview"
9
+ },
10
+ "license": "MIT",
11
+ "author": "5exyGuy (Aurėjus Remeika), wlk (https://github.com/kkwlkk)",
12
+ "description": "Webview/CEF package for the RageMP Mango Framework - a decorator-driven TypeScript framework for RageMP servers.",
13
+ "type": "module",
14
+ "main": "dist/index.js",
15
+ "types": "dist/index.d.ts",
16
+ "files": [
17
+ "dist"
18
+ ],
19
+ "dependencies": {},
20
+ "devDependencies": {
21
+ "tsup": "^8.0.2",
22
+ "typescript": "^5.4.5",
23
+ "@abraham/reflection": "^0.12.0",
24
+ "@ragemp-mango/core": "^2.0.6-beta.0"
25
+ },
26
+ "peerDependencies": {
27
+ "@ragempcommunity/types-cef": "^2.1.8",
28
+ "@ragemp-mango/core": "^2.0.6-beta.0"
29
+ },
30
+ "publishConfig": {
31
+ "access": "public",
32
+ "registry": "https://registry.npmjs.org/"
33
+ },
34
+ "scripts": {
35
+ "build": "tsup",
36
+ "dev": "tsup --watch",
37
+ "typecheck": "tsc --noEmit",
38
+ "types": "tsup --dts-only"
39
+ }
40
+ }