heimdall-react-native 0.1.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.
Files changed (49) hide show
  1. package/README.md +157 -0
  2. package/heimdall-react-native.podspec +18 -0
  3. package/ios/HeimdallNative.h +4 -0
  4. package/ios/HeimdallNative.m +151 -0
  5. package/lib/breadcrumbs.d.ts +12 -0
  6. package/lib/breadcrumbs.d.ts.map +1 -0
  7. package/lib/breadcrumbs.js +30 -0
  8. package/lib/breadcrumbs.js.map +1 -0
  9. package/lib/client.d.ts +26 -0
  10. package/lib/client.d.ts.map +1 -0
  11. package/lib/client.js +224 -0
  12. package/lib/client.js.map +1 -0
  13. package/lib/context.d.ts +5 -0
  14. package/lib/context.d.ts.map +1 -0
  15. package/lib/context.js +50 -0
  16. package/lib/context.js.map +1 -0
  17. package/lib/fingerprint.d.ts +3 -0
  18. package/lib/fingerprint.d.ts.map +1 -0
  19. package/lib/fingerprint.js +22 -0
  20. package/lib/fingerprint.js.map +1 -0
  21. package/lib/handlers/errorBoundary.d.ts +17 -0
  22. package/lib/handlers/errorBoundary.d.ts.map +1 -0
  23. package/lib/handlers/errorBoundary.js +40 -0
  24. package/lib/handlers/errorBoundary.js.map +1 -0
  25. package/lib/handlers/jsErrorHandler.d.ts +3 -0
  26. package/lib/handlers/jsErrorHandler.d.ts.map +1 -0
  27. package/lib/handlers/jsErrorHandler.js +35 -0
  28. package/lib/handlers/jsErrorHandler.js.map +1 -0
  29. package/lib/handlers/promiseHandler.d.ts +5 -0
  30. package/lib/handlers/promiseHandler.d.ts.map +1 -0
  31. package/lib/handlers/promiseHandler.js +45 -0
  32. package/lib/handlers/promiseHandler.js.map +1 -0
  33. package/lib/index.d.ts +14 -0
  34. package/lib/index.d.ts.map +1 -0
  35. package/lib/index.js +18 -0
  36. package/lib/index.js.map +1 -0
  37. package/lib/safeExec.d.ts +4 -0
  38. package/lib/safeExec.d.ts.map +1 -0
  39. package/lib/safeExec.js +31 -0
  40. package/lib/safeExec.js.map +1 -0
  41. package/lib/transport.d.ts +5 -0
  42. package/lib/transport.d.ts.map +1 -0
  43. package/lib/transport.js +142 -0
  44. package/lib/transport.js.map +1 -0
  45. package/lib/types.d.ts +103 -0
  46. package/lib/types.d.ts.map +1 -0
  47. package/lib/types.js +3 -0
  48. package/lib/types.js.map +1 -0
  49. package/package.json +39 -0
package/lib/context.js ADDED
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.setNativeModule = setNativeModule;
4
+ exports.getDeviceContext = getDeviceContext;
5
+ exports.clearContextCache = clearContextCache;
6
+ const react_native_1 = require("react-native");
7
+ const safeExec_1 = require("./safeExec");
8
+ let cachedContext = null;
9
+ let nativeModule = null;
10
+ function setNativeModule(mod) {
11
+ nativeModule = mod;
12
+ }
13
+ async function getDeviceContext(appVersion, buildNumber) {
14
+ if (cachedContext)
15
+ return cachedContext;
16
+ const ctx = {
17
+ model: 'Unknown',
18
+ osVersion: react_native_1.Platform.Version?.toString() ?? 'Unknown',
19
+ appVersion: appVersion ?? '0.0.0',
20
+ buildNumber: buildNumber ?? '0',
21
+ freeMemory: 0,
22
+ freeDisk: 0,
23
+ };
24
+ (0, safeExec_1.safeExec)(() => {
25
+ const { width, height } = react_native_1.Dimensions.get('window');
26
+ ctx.screenWidth = width;
27
+ ctx.screenHeight = height;
28
+ });
29
+ if (nativeModule?.getDeviceInfo) {
30
+ try {
31
+ const info = await nativeModule.getDeviceInfo();
32
+ if (info) {
33
+ ctx.model = info.model ?? ctx.model;
34
+ ctx.freeMemory = info.freeMemory ?? 0;
35
+ ctx.freeDisk = info.freeDisk ?? 0;
36
+ if (info.osVersion)
37
+ ctx.osVersion = info.osVersion;
38
+ }
39
+ }
40
+ catch (_) {
41
+ // native module not available, use defaults
42
+ }
43
+ }
44
+ cachedContext = ctx;
45
+ return ctx;
46
+ }
47
+ function clearContextCache() {
48
+ cachedContext = null;
49
+ }
50
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":";;AAOA,0CAEC;AAED,4CAqCC;AAED,8CAEC;AApDD,+CAAoD;AAEpD,yCAAsC;AAEtC,IAAI,aAAa,GAAyB,IAAI,CAAC;AAC/C,IAAI,YAAY,GAAQ,IAAI,CAAC;AAE7B,SAAgB,eAAe,CAAC,GAAQ;IACtC,YAAY,GAAG,GAAG,CAAC;AACrB,CAAC;AAEM,KAAK,UAAU,gBAAgB,CACpC,UAAmB,EACnB,WAAoB;IAEpB,IAAI,aAAa;QAAE,OAAO,aAAa,CAAC;IAExC,MAAM,GAAG,GAAkB;QACzB,KAAK,EAAE,SAAS;QAChB,SAAS,EAAE,uBAAQ,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,SAAS;QACpD,UAAU,EAAE,UAAU,IAAI,OAAO;QACjC,WAAW,EAAE,WAAW,IAAI,GAAG;QAC/B,UAAU,EAAE,CAAC;QACb,QAAQ,EAAE,CAAC;KACZ,CAAC;IAEF,IAAA,mBAAQ,EAAC,GAAG,EAAE;QACZ,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,yBAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClD,GAAW,CAAC,WAAW,GAAG,KAAK,CAAC;QAChC,GAAW,CAAC,YAAY,GAAG,MAAM,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,IAAI,YAAY,EAAE,aAAa,EAAE,CAAC;QAChC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,aAAa,EAAE,CAAC;YAChD,IAAI,IAAI,EAAE,CAAC;gBACT,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,GAAG,CAAC,KAAK,CAAC;gBACpC,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;gBACtC,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC;gBAClC,IAAI,IAAI,CAAC,SAAS;oBAAE,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;YACrD,CAAC;QACH,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,4CAA4C;QAC9C,CAAC;IACH,CAAC;IAED,aAAa,GAAG,GAAG,CAAC;IACpB,OAAO,GAAG,CAAC;AACb,CAAC;AAED,SAAgB,iBAAiB;IAC/B,aAAa,GAAG,IAAI,CAAC;AACvB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { StackFrame } from './types';
2
+ export declare function generateFingerprint(errorType: string, errorValue: string, stacktrace: StackFrame[]): string;
3
+ //# sourceMappingURL=fingerprint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.d.ts","sourceRoot":"","sources":["../src/fingerprint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,wBAAgB,mBAAmB,CACjC,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,UAAU,EAAE,GACvB,MAAM,CASR"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateFingerprint = generateFingerprint;
4
+ function generateFingerprint(errorType, errorValue, stacktrace) {
5
+ const topFrames = stacktrace
6
+ .filter((f) => f.in_app)
7
+ .slice(0, 3)
8
+ .map((f) => `${f.filename}:${f.function}:${f.lineno}`)
9
+ .join('|');
10
+ const raw = `${errorType}:${topFrames || errorValue}`;
11
+ return simpleHash(raw);
12
+ }
13
+ function simpleHash(str) {
14
+ let hash = 0;
15
+ for (let i = 0; i < str.length; i++) {
16
+ const char = str.charCodeAt(i);
17
+ hash = (hash << 5) - hash + char;
18
+ hash |= 0;
19
+ }
20
+ return Math.abs(hash).toString(36);
21
+ }
22
+ //# sourceMappingURL=fingerprint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.js","sourceRoot":"","sources":["../src/fingerprint.ts"],"names":[],"mappings":";;AAEA,kDAaC;AAbD,SAAgB,mBAAmB,CACjC,SAAiB,EACjB,UAAkB,EAClB,UAAwB;IAExB,MAAM,SAAS,GAAG,UAAU;SACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SACvB,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;SACX,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;SACrD,IAAI,CAAC,GAAG,CAAC,CAAC;IAEb,MAAM,GAAG,GAAG,GAAG,SAAS,IAAI,SAAS,IAAI,UAAU,EAAE,CAAC;IACtD,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC;AACzB,CAAC;AAED,SAAS,UAAU,CAAC,GAAW;IAC7B,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAI,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC;QACjC,IAAI,IAAI,CAAC,CAAC;IACZ,CAAC;IACD,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;AACrC,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { Component, ErrorInfo, ReactNode } from 'react';
2
+ interface Props {
3
+ children: ReactNode;
4
+ fallback?: ReactNode | ((error: Error) => ReactNode);
5
+ }
6
+ interface State {
7
+ hasError: boolean;
8
+ error: Error | null;
9
+ }
10
+ export declare class HeimdallErrorBoundary extends Component<Props, State> {
11
+ state: State;
12
+ static getDerivedStateFromError(error: Error): State;
13
+ componentDidCatch(error: Error, errorInfo: ErrorInfo): void;
14
+ render(): ReactNode;
15
+ }
16
+ export {};
17
+ //# sourceMappingURL=errorBoundary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errorBoundary.d.ts","sourceRoot":"","sources":["../../src/handlers/errorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAI/D,UAAU,KAAK;IACb,QAAQ,EAAE,SAAS,CAAC;IACpB,QAAQ,CAAC,EAAE,SAAS,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC;CACtD;AAED,UAAU,KAAK;IACb,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;CACrB;AAED,qBAAa,qBAAsB,SAAQ,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC;IAChE,KAAK,EAAE,KAAK,CAAoC;IAEhD,MAAM,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,GAAG,KAAK;IAIpD,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,GAAG,IAAI;IAY3D,MAAM,IAAI,SAAS;CAepB"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HeimdallErrorBoundary = void 0;
4
+ const react_1 = require("react");
5
+ const safeExec_1 = require("../safeExec");
6
+ const client_1 = require("../client");
7
+ class HeimdallErrorBoundary extends react_1.Component {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.state = { hasError: false, error: null };
11
+ }
12
+ static getDerivedStateFromError(error) {
13
+ return { hasError: true, error };
14
+ }
15
+ componentDidCatch(error, errorInfo) {
16
+ (0, safeExec_1.safeExec)(() => {
17
+ if (errorInfo.componentStack) {
18
+ client_1.heimdallClient.addBreadcrumb({
19
+ category: 'react',
20
+ message: `Component stack: ${errorInfo.componentStack}`,
21
+ });
22
+ }
23
+ client_1.heimdallClient.captureException(error, 'error');
24
+ });
25
+ }
26
+ render() {
27
+ if (this.state.hasError && this.state.error) {
28
+ if (typeof this.props.fallback === 'function') {
29
+ return this.props.fallback(this.state.error);
30
+ }
31
+ if (this.props.fallback) {
32
+ return this.props.fallback;
33
+ }
34
+ return null;
35
+ }
36
+ return this.props.children;
37
+ }
38
+ }
39
+ exports.HeimdallErrorBoundary = HeimdallErrorBoundary;
40
+ //# sourceMappingURL=errorBoundary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errorBoundary.js","sourceRoot":"","sources":["../../src/handlers/errorBoundary.tsx"],"names":[],"mappings":";;;AAAA,iCAA+D;AAC/D,0CAAuC;AACvC,sCAA2C;AAY3C,MAAa,qBAAsB,SAAQ,iBAAuB;IAAlE;;QACE,UAAK,GAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IAiClD,CAAC;IA/BC,MAAM,CAAC,wBAAwB,CAAC,KAAY;QAC1C,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,KAAY,EAAE,SAAoB;QAClD,IAAA,mBAAQ,EAAC,GAAG,EAAE;YACZ,IAAI,SAAS,CAAC,cAAc,EAAE,CAAC;gBAC7B,uBAAc,CAAC,aAAa,CAAC;oBAC3B,QAAQ,EAAE,OAAO;oBACjB,OAAO,EAAE,oBAAoB,SAAS,CAAC,cAAc,EAAE;iBACxD,CAAC,CAAC;YACL,CAAC;YACD,uBAAc,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAClD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAC5C,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,KAAK,UAAU,EAAE,CAAC;gBAC9C,OAAQ,IAAI,CAAC,KAAK,CAAC,QAAwC,CACzD,IAAI,CAAC,KAAK,CAAC,KAAK,CACjB,CAAC;YACJ,CAAC;YACD,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;gBACxB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;YAC7B,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;CACF;AAlCD,sDAkCC"}
@@ -0,0 +1,3 @@
1
+ export declare function installJsErrorHandler(callback: (error: Error, isFatal: boolean) => void): void;
2
+ export declare function uninstallJsErrorHandler(): void;
3
+ //# sourceMappingURL=jsErrorHandler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsErrorHandler.d.ts","sourceRoot":"","sources":["../../src/handlers/jsErrorHandler.ts"],"names":[],"mappings":"AAcA,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,GACjD,IAAI,CAoBN;AAED,wBAAgB,uBAAuB,IAAI,IAAI,CAO9C"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.installJsErrorHandler = installJsErrorHandler;
4
+ exports.uninstallJsErrorHandler = uninstallJsErrorHandler;
5
+ const safeExec_1 = require("../safeExec");
6
+ let originalHandler = null;
7
+ let installed = false;
8
+ function installJsErrorHandler(callback) {
9
+ if (installed)
10
+ return;
11
+ (0, safeExec_1.safeExec)(() => {
12
+ if (!global.ErrorUtils)
13
+ return;
14
+ originalHandler = global.ErrorUtils.getGlobalHandler();
15
+ global.ErrorUtils.setGlobalHandler((error, isFatal) => {
16
+ // Capture the error for Heimdall first
17
+ (0, safeExec_1.safeExec)(() => callback(error, isFatal));
18
+ // Always chain to the original handler so the app's default behavior is preserved
19
+ if (originalHandler) {
20
+ originalHandler(error, isFatal);
21
+ }
22
+ });
23
+ installed = true;
24
+ });
25
+ }
26
+ function uninstallJsErrorHandler() {
27
+ (0, safeExec_1.safeExec)(() => {
28
+ if (!installed || !global.ErrorUtils || !originalHandler)
29
+ return;
30
+ global.ErrorUtils.setGlobalHandler(originalHandler);
31
+ originalHandler = null;
32
+ installed = false;
33
+ });
34
+ }
35
+ //# sourceMappingURL=jsErrorHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsErrorHandler.js","sourceRoot":"","sources":["../../src/handlers/jsErrorHandler.ts"],"names":[],"mappings":";;AAcA,sDAsBC;AAED,0DAOC;AA7CD,0CAAuC;AAIvC,IAAI,eAAe,GAAwB,IAAI,CAAC;AAChD,IAAI,SAAS,GAAG,KAAK,CAAC;AAStB,SAAgB,qBAAqB,CACnC,QAAkD;IAElD,IAAI,SAAS;QAAE,OAAO;IAEtB,IAAA,mBAAQ,EAAC,GAAG,EAAE;QACZ,IAAI,CAAC,MAAM,CAAC,UAAU;YAAE,OAAO;QAE/B,eAAe,GAAG,MAAM,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;QAEvD,MAAM,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,KAAY,EAAE,OAAgB,EAAE,EAAE;YACpE,uCAAuC;YACvC,IAAA,mBAAQ,EAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC;YAEzC,kFAAkF;YAClF,IAAI,eAAe,EAAE,CAAC;gBACpB,eAAe,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAClC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,SAAS,GAAG,IAAI,CAAC;IACnB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,uBAAuB;IACrC,IAAA,mBAAQ,EAAC,GAAG,EAAE;QACZ,IAAI,CAAC,SAAS,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,eAAe;YAAE,OAAO;QACjE,MAAM,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;QACpD,eAAe,GAAG,IAAI,CAAC;QACvB,SAAS,GAAG,KAAK,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,5 @@
1
+ type RejectionCallback = (reason: unknown) => void;
2
+ export declare function installPromiseHandler(callback: RejectionCallback): void;
3
+ export declare function uninstallPromiseHandler(): void;
4
+ export {};
5
+ //# sourceMappingURL=promiseHandler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"promiseHandler.d.ts","sourceRoot":"","sources":["../../src/handlers/promiseHandler.ts"],"names":[],"mappings":"AAEA,KAAK,iBAAiB,GAAG,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;AAgBnD,wBAAgB,qBAAqB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,IAAI,CA0BvE;AAED,wBAAgB,uBAAuB,IAAI,IAAI,CAc9C"}
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.installPromiseHandler = installPromiseHandler;
4
+ exports.uninstallPromiseHandler = uninstallPromiseHandler;
5
+ const safeExec_1 = require("../safeExec");
6
+ let installed = false;
7
+ let polyfillTracking = null;
8
+ function installPromiseHandler(callback) {
9
+ if (installed)
10
+ return;
11
+ (0, safeExec_1.safeExec)(() => {
12
+ // Hermes engine
13
+ if (global.HermesInternal?.enablePromiseRejectionTracker) {
14
+ global.HermesInternal.enablePromiseRejectionTracker({
15
+ allRejections: true,
16
+ onUnhandled: (_id, error) => {
17
+ (0, safeExec_1.safeExec)(() => callback(error));
18
+ },
19
+ });
20
+ installed = true;
21
+ return;
22
+ }
23
+ // JSC / fallback: use the global unhandledrejection event if available
24
+ if (typeof globalThis !== 'undefined') {
25
+ const handler = (event) => {
26
+ (0, safeExec_1.safeExec)(() => callback(event?.reason));
27
+ };
28
+ globalThis.addEventListener?.('unhandledrejection', handler);
29
+ polyfillTracking = handler;
30
+ installed = true;
31
+ }
32
+ });
33
+ }
34
+ function uninstallPromiseHandler() {
35
+ (0, safeExec_1.safeExec)(() => {
36
+ if (!installed)
37
+ return;
38
+ if (polyfillTracking && typeof globalThis !== 'undefined') {
39
+ globalThis.removeEventListener?.('unhandledrejection', polyfillTracking);
40
+ polyfillTracking = null;
41
+ }
42
+ installed = false;
43
+ });
44
+ }
45
+ //# sourceMappingURL=promiseHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"promiseHandler.js","sourceRoot":"","sources":["../../src/handlers/promiseHandler.ts"],"names":[],"mappings":";;AAkBA,sDA0BC;AAED,0DAcC;AA5DD,0CAAuC;AAIvC,IAAI,SAAS,GAAG,KAAK,CAAC;AACtB,IAAI,gBAAgB,GAAQ,IAAI,CAAC;AAajC,SAAgB,qBAAqB,CAAC,QAA2B;IAC/D,IAAI,SAAS;QAAE,OAAO;IAEtB,IAAA,mBAAQ,EAAC,GAAG,EAAE;QACZ,gBAAgB;QAChB,IAAI,MAAM,CAAC,cAAc,EAAE,6BAA6B,EAAE,CAAC;YACzD,MAAM,CAAC,cAAc,CAAC,6BAA6B,CAAC;gBAClD,aAAa,EAAE,IAAI;gBACnB,WAAW,EAAE,CAAC,GAAW,EAAE,KAAc,EAAE,EAAE;oBAC3C,IAAA,mBAAQ,EAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;gBAClC,CAAC;aACF,CAAC,CAAC;YACH,SAAS,GAAG,IAAI,CAAC;YACjB,OAAO;QACT,CAAC;QAED,uEAAuE;QACvE,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE,CAAC;YACtC,MAAM,OAAO,GAAG,CAAC,KAAU,EAAE,EAAE;gBAC7B,IAAA,mBAAQ,EAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;YAC1C,CAAC,CAAC;YACD,UAAkB,CAAC,gBAAgB,EAAE,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAC;YACtE,gBAAgB,GAAG,OAAO,CAAC;YAC3B,SAAS,GAAG,IAAI,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,uBAAuB;IACrC,IAAA,mBAAQ,EAAC,GAAG,EAAE;QACZ,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,IAAI,gBAAgB,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE,CAAC;YACzD,UAAkB,CAAC,mBAAmB,EAAE,CACvC,oBAAoB,EACpB,gBAAgB,CACjB,CAAC;YACF,gBAAgB,GAAG,IAAI,CAAC;QAC1B,CAAC;QAED,SAAS,GAAG,KAAK,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC"}
package/lib/index.d.ts ADDED
@@ -0,0 +1,14 @@
1
+ export { HeimdallErrorBoundary } from './handlers/errorBoundary';
2
+ export type { HeimdallConfig, FirebaseConfig, CrashEvent, StackFrame, Breadcrumb, UserContext, DeviceContext, EventType, EventLevel, Mechanism, } from './types';
3
+ declare const Heimdall: {
4
+ init: (config: import("./types").HeimdallConfig) => void;
5
+ captureException: (error: Error, level?: import("./types").EventLevel) => void;
6
+ captureMessage: (message: string, level?: import("./types").EventLevel) => void;
7
+ addBreadcrumb: (crumb: Omit<import("./types").Breadcrumb, "timestamp">) => void;
8
+ setUser: (user: import("./types").UserContext) => void;
9
+ setTag: (key: string, value: string) => void;
10
+ clearUser: () => void;
11
+ destroy: () => void;
12
+ };
13
+ export default Heimdall;
14
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,YAAY,EACV,cAAc,EACd,cAAc,EACd,UAAU,EACV,UAAU,EACV,UAAU,EACV,WAAW,EACX,aAAa,EACb,SAAS,EACT,UAAU,EACV,SAAS,GACV,MAAM,SAAS,CAAC;AAEjB,QAAA,MAAM,QAAQ;;;;;;;;;CASb,CAAC;AAEF,eAAe,QAAQ,CAAC"}
package/lib/index.js ADDED
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HeimdallErrorBoundary = void 0;
4
+ const client_1 = require("./client");
5
+ var errorBoundary_1 = require("./handlers/errorBoundary");
6
+ Object.defineProperty(exports, "HeimdallErrorBoundary", { enumerable: true, get: function () { return errorBoundary_1.HeimdallErrorBoundary; } });
7
+ const Heimdall = {
8
+ init: client_1.heimdallClient.init.bind(client_1.heimdallClient),
9
+ captureException: client_1.heimdallClient.captureException.bind(client_1.heimdallClient),
10
+ captureMessage: client_1.heimdallClient.captureMessage.bind(client_1.heimdallClient),
11
+ addBreadcrumb: client_1.heimdallClient.addBreadcrumb.bind(client_1.heimdallClient),
12
+ setUser: client_1.heimdallClient.setUser.bind(client_1.heimdallClient),
13
+ setTag: client_1.heimdallClient.setTag.bind(client_1.heimdallClient),
14
+ clearUser: client_1.heimdallClient.clearUser.bind(client_1.heimdallClient),
15
+ destroy: client_1.heimdallClient.destroy.bind(client_1.heimdallClient),
16
+ };
17
+ exports.default = Heimdall;
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,qCAA0C;AAE1C,0DAAiE;AAAxD,sHAAA,qBAAqB,OAAA;AAc9B,MAAM,QAAQ,GAAG;IACf,IAAI,EAAE,uBAAc,CAAC,IAAI,CAAC,IAAI,CAAC,uBAAc,CAAC;IAC9C,gBAAgB,EAAE,uBAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,uBAAc,CAAC;IACtE,cAAc,EAAE,uBAAc,CAAC,cAAc,CAAC,IAAI,CAAC,uBAAc,CAAC;IAClE,aAAa,EAAE,uBAAc,CAAC,aAAa,CAAC,IAAI,CAAC,uBAAc,CAAC;IAChE,OAAO,EAAE,uBAAc,CAAC,OAAO,CAAC,IAAI,CAAC,uBAAc,CAAC;IACpD,MAAM,EAAE,uBAAc,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAc,CAAC;IAClD,SAAS,EAAE,uBAAc,CAAC,SAAS,CAAC,IAAI,CAAC,uBAAc,CAAC;IACxD,OAAO,EAAE,uBAAc,CAAC,OAAO,CAAC,IAAI,CAAC,uBAAc,CAAC;CACrD,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function setDebugMode(enabled: boolean): void;
2
+ export declare function safeExec(fn: () => void): void;
3
+ export declare function safeExecAsync<T>(fn: () => Promise<T>): Promise<T | undefined>;
4
+ //# sourceMappingURL=safeExec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"safeExec.d.ts","sourceRoot":"","sources":["../src/safeExec.ts"],"names":[],"mappings":"AAEA,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAEnD;AAED,wBAAgB,QAAQ,CAAC,EAAE,EAAE,MAAM,IAAI,GAAG,IAAI,CAQ7C;AAED,wBAAsB,aAAa,CAAC,CAAC,EACnC,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GACnB,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC,CASxB"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.setDebugMode = setDebugMode;
4
+ exports.safeExec = safeExec;
5
+ exports.safeExecAsync = safeExecAsync;
6
+ let debugMode = false;
7
+ function setDebugMode(enabled) {
8
+ debugMode = enabled;
9
+ }
10
+ function safeExec(fn) {
11
+ try {
12
+ fn();
13
+ }
14
+ catch (e) {
15
+ if (debugMode) {
16
+ console.warn('[Heimdall] SafeExec caught error:', e);
17
+ }
18
+ }
19
+ }
20
+ async function safeExecAsync(fn) {
21
+ try {
22
+ return await fn();
23
+ }
24
+ catch (e) {
25
+ if (debugMode) {
26
+ console.warn('[Heimdall] SafeExecAsync caught error:', e);
27
+ }
28
+ return undefined;
29
+ }
30
+ }
31
+ //# sourceMappingURL=safeExec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"safeExec.js","sourceRoot":"","sources":["../src/safeExec.ts"],"names":[],"mappings":";;AAEA,oCAEC;AAED,4BAQC;AAED,sCAWC;AA3BD,IAAI,SAAS,GAAG,KAAK,CAAC;AAEtB,SAAgB,YAAY,CAAC,OAAgB;IAC3C,SAAS,GAAG,OAAO,CAAC;AACtB,CAAC;AAED,SAAgB,QAAQ,CAAC,EAAc;IACrC,IAAI,CAAC;QACH,EAAE,EAAE,CAAC;IACP,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,CAAC,IAAI,CAAC,mCAAmC,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;AACH,CAAC;AAEM,KAAK,UAAU,aAAa,CACjC,EAAoB;IAEpB,IAAI,CAAC;QACH,OAAO,MAAM,EAAE,EAAE,CAAC;IACpB,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,CAAC,IAAI,CAAC,wCAAwC,EAAE,CAAC,CAAC,CAAC;QAC5D,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { CrashEvent, FirebaseConfig } from './types';
2
+ export declare function initFirebase(firebaseConfig: FirebaseConfig): void;
3
+ export declare function sendEvent(event: CrashEvent): Promise<void>;
4
+ export declare function sendPendingEvents(): Promise<void>;
5
+ //# sourceMappingURL=transport.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../src/transport.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,UAAU,EAAiC,cAAc,EAAE,MAAM,SAAS,CAAC;AAiBpF,wBAAgB,YAAY,CAAC,cAAc,EAAE,cAAc,GAAG,IAAI,CAMjE;AAuBD,wBAAsB,SAAS,CAAC,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAmChE;AAqDD,wBAAsB,iBAAiB,IAAI,OAAO,CAAC,IAAI,CAAC,CAcvD"}
@@ -0,0 +1,142 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.initFirebase = initFirebase;
4
+ exports.sendEvent = sendEvent;
5
+ exports.sendPendingEvents = sendPendingEvents;
6
+ const app_1 = require("firebase/app");
7
+ const firestore_1 = require("firebase/firestore");
8
+ const safeExec_1 = require("./safeExec");
9
+ const HEIMDALL_APP_NAME = '__heimdall__';
10
+ const QUEUE_KEY = '@heimdall_event_queue';
11
+ let app = null;
12
+ let db = null;
13
+ let AsyncStorage = null;
14
+ try {
15
+ AsyncStorage =
16
+ require('@react-native-async-storage/async-storage').default;
17
+ }
18
+ catch (_) {
19
+ // AsyncStorage not available, offline queue disabled
20
+ }
21
+ function initFirebase(firebaseConfig) {
22
+ if (db)
23
+ return;
24
+ const existing = (0, app_1.getApps)().find((a) => a.name === HEIMDALL_APP_NAME);
25
+ app = existing ?? (0, app_1.initializeApp)(firebaseConfig, HEIMDALL_APP_NAME);
26
+ db = (0, firestore_1.getFirestore)(app);
27
+ }
28
+ async function resolveAppId(apiKey) {
29
+ if (!db)
30
+ return null;
31
+ const keyDoc = await (0, firestore_1.getDoc)((0, firestore_1.doc)(db, 'apiKeys', apiKey));
32
+ if (!keyDoc.exists())
33
+ return null;
34
+ const data = keyDoc.data();
35
+ if (!data.active)
36
+ return null;
37
+ return data.appId;
38
+ }
39
+ const appIdCache = new Map();
40
+ async function getAppId(apiKey) {
41
+ if (appIdCache.has(apiKey))
42
+ return appIdCache.get(apiKey);
43
+ const appId = await resolveAppId(apiKey);
44
+ if (appId)
45
+ appIdCache.set(apiKey, appId);
46
+ return appId;
47
+ }
48
+ async function sendEvent(event) {
49
+ if (!db || !event.apiKey) {
50
+ await queueEvent(event);
51
+ return;
52
+ }
53
+ const appId = await getAppId(event.apiKey);
54
+ if (!appId) {
55
+ await queueEvent(event);
56
+ return;
57
+ }
58
+ event.appId = appId;
59
+ try {
60
+ // Write the event
61
+ await (0, firestore_1.setDoc)((0, firestore_1.doc)(db, 'apps', appId, 'events', event.id), event);
62
+ // Upsert the issue
63
+ await upsertIssue(appId, event);
64
+ // Update app-level metadata
65
+ await (0, safeExec_1.safeExecAsync)(async () => {
66
+ const appRef = (0, firestore_1.doc)(db, 'apps', appId);
67
+ const appDoc = await (0, firestore_1.getDoc)(appRef);
68
+ if (appDoc.exists()) {
69
+ await (0, firestore_1.updateDoc)(appRef, {
70
+ lastSeen: Date.now(),
71
+ eventCount: (0, firestore_1.increment)(1),
72
+ });
73
+ }
74
+ });
75
+ }
76
+ catch (_) {
77
+ await queueEvent(event);
78
+ }
79
+ }
80
+ async function upsertIssue(appId, event) {
81
+ if (!db)
82
+ return;
83
+ const issueRef = (0, firestore_1.doc)(db, 'apps', appId, 'issues', event.fingerprint);
84
+ const issueSnap = await (0, firestore_1.getDoc)(issueRef);
85
+ const lastEventSubset = {
86
+ id: event.id,
87
+ timestamp: event.timestamp,
88
+ device: event.device,
89
+ exceptionValue: event.exception.value,
90
+ };
91
+ if (issueSnap.exists()) {
92
+ await (0, firestore_1.updateDoc)(issueRef, {
93
+ lastSeen: event.timestamp,
94
+ count: (0, firestore_1.increment)(1),
95
+ level: event.level,
96
+ lastEvent: lastEventSubset,
97
+ });
98
+ }
99
+ else {
100
+ const issue = {
101
+ fingerprint: event.fingerprint,
102
+ title: `${event.exception.type}: ${event.exception.value}`,
103
+ lastSeen: event.timestamp,
104
+ firstSeen: event.timestamp,
105
+ count: 1,
106
+ level: event.level,
107
+ status: 'unresolved',
108
+ mechanism: event.exception.mechanism,
109
+ appId,
110
+ appName: '',
111
+ lastEvent: lastEventSubset,
112
+ };
113
+ await (0, firestore_1.setDoc)(issueRef, issue);
114
+ }
115
+ }
116
+ async function queueEvent(event) {
117
+ if (!AsyncStorage)
118
+ return;
119
+ await (0, safeExec_1.safeExecAsync)(async () => {
120
+ const raw = await AsyncStorage.getItem(QUEUE_KEY);
121
+ const queue = raw ? JSON.parse(raw) : [];
122
+ queue.push(event);
123
+ // Cap the queue at 50 to avoid storage bloat
124
+ const trimmed = queue.slice(-50);
125
+ await AsyncStorage.setItem(QUEUE_KEY, JSON.stringify(trimmed));
126
+ });
127
+ }
128
+ async function sendPendingEvents() {
129
+ if (!AsyncStorage || !db)
130
+ return;
131
+ await (0, safeExec_1.safeExecAsync)(async () => {
132
+ const raw = await AsyncStorage.getItem(QUEUE_KEY);
133
+ if (!raw)
134
+ return;
135
+ const queue = JSON.parse(raw);
136
+ await AsyncStorage.removeItem(QUEUE_KEY);
137
+ for (const event of queue) {
138
+ await (0, safeExec_1.safeExecAsync)(() => sendEvent(event));
139
+ }
140
+ });
141
+ }
142
+ //# sourceMappingURL=transport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport.js","sourceRoot":"","sources":["../src/transport.ts"],"names":[],"mappings":"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"}
package/lib/types.d.ts ADDED
@@ -0,0 +1,103 @@
1
+ export interface FirebaseConfig {
2
+ apiKey: string;
3
+ authDomain: string;
4
+ projectId: string;
5
+ storageBucket: string;
6
+ messagingSenderId: string;
7
+ appId: string;
8
+ measurementId?: string;
9
+ }
10
+ export interface HeimdallConfig {
11
+ apiKey: string;
12
+ firebaseConfig: FirebaseConfig;
13
+ enableNativeCrashHandling?: boolean;
14
+ enableJsErrorHandler?: boolean;
15
+ enablePromiseRejectionHandler?: boolean;
16
+ maxBreadcrumbs?: number;
17
+ debug?: boolean;
18
+ beforeSend?: (event: CrashEvent) => CrashEvent | null;
19
+ }
20
+ export interface StackFrame {
21
+ filename: string;
22
+ function: string;
23
+ lineno: number;
24
+ colno: number;
25
+ in_app: boolean;
26
+ }
27
+ export type EventType = 'error' | 'crash' | 'message';
28
+ export type EventLevel = 'fatal' | 'error' | 'warning' | 'info';
29
+ export type Mechanism = 'jsHandler' | 'promiseRejection' | 'nativeCrash' | 'errorBoundary' | 'manual';
30
+ export type IssueStatus = 'unresolved' | 'resolved' | 'ignored';
31
+ export interface ExceptionPayload {
32
+ type: string;
33
+ value: string;
34
+ stacktrace: StackFrame[];
35
+ mechanism: Mechanism;
36
+ }
37
+ export interface DeviceContext {
38
+ model: string;
39
+ osVersion: string;
40
+ appVersion: string;
41
+ buildNumber: string;
42
+ freeMemory: number;
43
+ freeDisk: number;
44
+ }
45
+ export interface Breadcrumb {
46
+ timestamp: number;
47
+ category: string;
48
+ message: string;
49
+ level?: EventLevel;
50
+ data?: Record<string, unknown>;
51
+ }
52
+ export interface UserContext {
53
+ id?: string;
54
+ email?: string;
55
+ username?: string;
56
+ extra?: Record<string, unknown>;
57
+ }
58
+ export interface CrashEvent {
59
+ id: string;
60
+ apiKey: string;
61
+ appId: string;
62
+ type: EventType;
63
+ level: EventLevel;
64
+ timestamp: number;
65
+ fingerprint: string;
66
+ exception: ExceptionPayload;
67
+ device: DeviceContext;
68
+ breadcrumbs: Breadcrumb[];
69
+ user?: UserContext;
70
+ tags?: Record<string, string>;
71
+ }
72
+ export interface IssueDocument {
73
+ fingerprint: string;
74
+ title: string;
75
+ lastSeen: number;
76
+ firstSeen: number;
77
+ count: number;
78
+ level: EventLevel;
79
+ status: IssueStatus;
80
+ mechanism: Mechanism;
81
+ appId: string;
82
+ appName: string;
83
+ lastEvent: {
84
+ id: string;
85
+ timestamp: number;
86
+ device: DeviceContext;
87
+ exceptionValue: string;
88
+ };
89
+ }
90
+ export interface AppDocument {
91
+ name: string;
92
+ apiKey: string;
93
+ createdAt: number;
94
+ lastSeen: number;
95
+ eventCount: number;
96
+ }
97
+ export interface ApiKeyDocument {
98
+ appId: string;
99
+ appName: string;
100
+ createdAt: number;
101
+ active: boolean;
102
+ }
103
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,cAAc,CAAC;IAC/B,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,6BAA6B,CAAC,EAAE,OAAO,CAAC;IACxC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,KAAK,UAAU,GAAG,IAAI,CAAC;CACvD;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;AACtD,MAAM,MAAM,UAAU,GAAG,OAAO,GAAG,OAAO,GAAG,SAAS,GAAG,MAAM,CAAC;AAChE,MAAM,MAAM,SAAS,GACjB,WAAW,GACX,kBAAkB,GAClB,aAAa,GACb,eAAe,GACf,QAAQ,CAAC;AACb,MAAM,MAAM,WAAW,GAAG,YAAY,GAAG,UAAU,GAAG,SAAS,CAAC;AAEhE,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,UAAU,EAAE,CAAC;IACzB,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,UAAU;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AAED,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,SAAS,CAAC;IAChB,KAAK,EAAE,UAAU,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,gBAAgB,CAAC;IAC5B,MAAM,EAAE,aAAa,CAAC;IACtB,WAAW,EAAE,UAAU,EAAE,CAAC;IAC1B,IAAI,CAAC,EAAE,WAAW,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC/B;AAED,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,UAAU,CAAC;IAClB,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,SAAS,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE;QACT,EAAE,EAAE,MAAM,CAAC;QACX,SAAS,EAAE,MAAM,CAAC;QAClB,MAAM,EAAE,aAAa,CAAC;QACtB,cAAc,EAAE,MAAM,CAAC;KACxB,CAAC;CACH;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,OAAO,CAAC;CACjB"}
package/lib/types.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}