@logcaffe/browser 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/dist/breadcrumbs.d.ts +11 -0
  2. package/dist/breadcrumbs.d.ts.map +1 -0
  3. package/dist/breadcrumbs.js +96 -0
  4. package/dist/breadcrumbs.js.map +1 -0
  5. package/dist/buffer.d.ts +18 -0
  6. package/dist/buffer.d.ts.map +1 -0
  7. package/dist/buffer.js +58 -0
  8. package/dist/buffer.js.map +1 -0
  9. package/dist/client.d.ts +10 -0
  10. package/dist/client.d.ts.map +1 -0
  11. package/dist/client.js +43 -0
  12. package/dist/client.js.map +1 -0
  13. package/dist/collectors/console.d.ts +4 -0
  14. package/dist/collectors/console.d.ts.map +1 -0
  15. package/dist/collectors/console.js +45 -0
  16. package/dist/collectors/console.js.map +1 -0
  17. package/dist/collectors/errors.d.ts +7 -0
  18. package/dist/collectors/errors.d.ts.map +1 -0
  19. package/dist/collectors/errors.js +108 -0
  20. package/dist/collectors/errors.js.map +1 -0
  21. package/dist/collectors/network.d.ts +4 -0
  22. package/dist/collectors/network.d.ts.map +1 -0
  23. package/dist/collectors/network.js +50 -0
  24. package/dist/collectors/network.js.map +1 -0
  25. package/dist/collectors/performance.d.ts +3 -0
  26. package/dist/collectors/performance.d.ts.map +1 -0
  27. package/dist/collectors/performance.js +113 -0
  28. package/dist/collectors/performance.js.map +1 -0
  29. package/dist/context.d.ts +10 -0
  30. package/dist/context.d.ts.map +1 -0
  31. package/dist/context.js +35 -0
  32. package/dist/context.js.map +1 -0
  33. package/dist/device.d.ts +12 -0
  34. package/dist/device.d.ts.map +1 -0
  35. package/dist/device.js +85 -0
  36. package/dist/device.js.map +1 -0
  37. package/dist/fingerprint.d.ts +6 -0
  38. package/dist/fingerprint.d.ts.map +1 -0
  39. package/dist/fingerprint.js +48 -0
  40. package/dist/fingerprint.js.map +1 -0
  41. package/dist/index.d.ts +28 -0
  42. package/dist/index.d.ts.map +1 -0
  43. package/dist/index.js +156 -0
  44. package/dist/index.js.map +1 -0
  45. package/dist/react/ErrorBoundary.d.ts +21 -0
  46. package/dist/react/ErrorBoundary.d.ts.map +1 -0
  47. package/dist/react/ErrorBoundary.js +43 -0
  48. package/dist/react/ErrorBoundary.js.map +1 -0
  49. package/dist/types.d.ts +25 -0
  50. package/dist/types.d.ts.map +1 -0
  51. package/dist/types.js +3 -0
  52. package/dist/types.js.map +1 -0
  53. package/package.json +38 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"performance.js","sourceRoot":"","sources":["../../src/collectors/performance.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ export interface UserContext {
2
+ id?: string;
3
+ email?: string;
4
+ name?: string;
5
+ [key: string]: unknown;
6
+ }
7
+ export declare function setUser(user: UserContext | null): void;
8
+ export declare function getUser(): UserContext | null;
9
+ export declare function getSessionId(): string;
10
+ //# sourceMappingURL=context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAKD,wBAAgB,OAAO,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,GAAG,IAAI,CAEtD;AAED,wBAAgB,OAAO,IAAI,WAAW,GAAG,IAAI,CAE5C;AAED,wBAAgB,YAAY,IAAI,MAAM,CAIrC"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.setUser = setUser;
4
+ exports.getUser = getUser;
5
+ exports.getSessionId = getSessionId;
6
+ let currentUser = null;
7
+ let sessionId = null;
8
+ function setUser(user) {
9
+ currentUser = user;
10
+ }
11
+ function getUser() {
12
+ return currentUser;
13
+ }
14
+ function getSessionId() {
15
+ if (sessionId)
16
+ return sessionId;
17
+ sessionId = generateSessionId();
18
+ return sessionId;
19
+ }
20
+ function generateSessionId() {
21
+ try {
22
+ // Persist across page loads within same tab
23
+ let sid = sessionStorage.getItem('logcaffe_session_id');
24
+ if (!sid) {
25
+ sid = crypto.randomUUID();
26
+ sessionStorage.setItem('logcaffe_session_id', sid);
27
+ }
28
+ return sid;
29
+ }
30
+ catch {
31
+ // sessionStorage unavailable (e.g. incognito in some browsers)
32
+ return crypto.randomUUID();
33
+ }
34
+ }
35
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../src/context.ts"],"names":[],"mappings":";;AAUA,0BAEC;AAED,0BAEC;AAED,oCAIC;AAfD,IAAI,WAAW,GAAuB,IAAI,CAAC;AAC3C,IAAI,SAAS,GAAkB,IAAI,CAAC;AAEpC,SAAgB,OAAO,CAAC,IAAwB;IAC9C,WAAW,GAAG,IAAI,CAAC;AACrB,CAAC;AAED,SAAgB,OAAO;IACrB,OAAO,WAAW,CAAC;AACrB,CAAC;AAED,SAAgB,YAAY;IAC1B,IAAI,SAAS;QAAE,OAAO,SAAS,CAAC;IAChC,SAAS,GAAG,iBAAiB,EAAE,CAAC;IAChC,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,iBAAiB;IACxB,IAAI,CAAC;QACH,4CAA4C;QAC5C,IAAI,GAAG,GAAG,cAAc,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;QACxD,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,GAAG,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;YAC1B,cAAc,CAAC,OAAO,CAAC,qBAAqB,EAAE,GAAG,CAAC,CAAC;QACrD,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,MAAM,CAAC;QACP,+DAA+D;QAC/D,OAAO,MAAM,CAAC,UAAU,EAAE,CAAC;IAC7B,CAAC;AACH,CAAC"}
@@ -0,0 +1,12 @@
1
+ export interface DeviceInfo {
2
+ browserName: string;
3
+ browserVersion: string;
4
+ osName: string;
5
+ osVersion: string;
6
+ deviceType: 'desktop' | 'mobile' | 'tablet';
7
+ screenSize: string;
8
+ connectionType?: string;
9
+ language: string;
10
+ }
11
+ export declare function getDeviceInfo(): DeviceInfo;
12
+ //# sourceMappingURL=device.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"device.d.ts","sourceRoot":"","sources":["../src/device.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,SAAS,GAAG,QAAQ,GAAG,QAAQ,CAAC;IAC5C,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,wBAAgB,aAAa,IAAI,UAAU,CAa1C"}
package/dist/device.js ADDED
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getDeviceInfo = getDeviceInfo;
4
+ function getDeviceInfo() {
5
+ const ua = navigator.userAgent;
6
+ return {
7
+ browserName: parseBrowserName(ua),
8
+ browserVersion: parseBrowserVersion(ua),
9
+ osName: parseOSName(ua),
10
+ osVersion: parseOSVersion(ua),
11
+ deviceType: detectDeviceType(ua),
12
+ screenSize: `${screen.width}x${screen.height}`,
13
+ connectionType: navigator.connection?.effectiveType,
14
+ language: navigator.language,
15
+ };
16
+ }
17
+ function parseBrowserName(ua) {
18
+ if (ua.includes('Firefox'))
19
+ return 'Firefox';
20
+ if (ua.includes('Edg'))
21
+ return 'Edge';
22
+ if (ua.includes('OPR') || ua.includes('Opera'))
23
+ return 'Opera';
24
+ if (ua.includes('Chrome'))
25
+ return 'Chrome';
26
+ if (ua.includes('Safari'))
27
+ return 'Safari';
28
+ return 'Unknown';
29
+ }
30
+ function parseBrowserVersion(ua) {
31
+ const patterns = [
32
+ ['Firefox', /Firefox\/(\d+[\d.]*)/],
33
+ ['Edge', /Edg\/(\d+[\d.]*)/],
34
+ ['Opera', /(?:OPR|Opera)\/(\d+[\d.]*)/],
35
+ ['Chrome', /Chrome\/(\d+[\d.]*)/],
36
+ ['Safari', /Version\/(\d+[\d.]*)/],
37
+ ];
38
+ for (const [name, regex] of patterns) {
39
+ if (ua.includes(name === 'Opera' ? 'OPR' : name) || ua.includes(name)) {
40
+ const match = ua.match(regex);
41
+ if (match?.[1])
42
+ return match[1];
43
+ }
44
+ }
45
+ return 'Unknown';
46
+ }
47
+ function parseOSName(ua) {
48
+ if (ua.includes('Windows'))
49
+ return 'Windows';
50
+ if (ua.includes('Mac OS X') || ua.includes('Macintosh'))
51
+ return 'macOS';
52
+ if (ua.includes('Linux') && !ua.includes('Android'))
53
+ return 'Linux';
54
+ if (ua.includes('Android'))
55
+ return 'Android';
56
+ if (ua.includes('iPhone') || ua.includes('iPad') || ua.includes('iPod'))
57
+ return 'iOS';
58
+ if (ua.includes('CrOS'))
59
+ return 'ChromeOS';
60
+ return 'Unknown';
61
+ }
62
+ function parseOSVersion(ua) {
63
+ const patterns = {
64
+ Windows: /Windows NT (\d+[\d.]*)/,
65
+ macOS: /Mac OS X (\d+[._\d]*)/,
66
+ Android: /Android (\d+[\d.]*)/,
67
+ iOS: /OS (\d+[._\d]*)/,
68
+ };
69
+ const osName = parseOSName(ua);
70
+ const regex = patterns[osName];
71
+ if (regex) {
72
+ const match = ua.match(regex);
73
+ if (match?.[1])
74
+ return match[1].replace(/_/g, '.');
75
+ }
76
+ return 'Unknown';
77
+ }
78
+ function detectDeviceType(ua) {
79
+ if (/iPad|tablet/i.test(ua))
80
+ return 'tablet';
81
+ if (/Mobi|Android.*Mobile|iPhone|iPod/i.test(ua))
82
+ return 'mobile';
83
+ return 'desktop';
84
+ }
85
+ //# sourceMappingURL=device.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"device.js","sourceRoot":"","sources":["../src/device.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Generate a fingerprint for browser errors (for error grouping).
3
+ * Uses SubtleCrypto for SHA-256 in the browser.
4
+ */
5
+ export declare function generateBrowserFingerprint(message: string, stack?: string): string;
6
+ //# sourceMappingURL=fingerprint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.d.ts","sourceRoot":"","sources":["../src/fingerprint.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,0BAA0B,CACxC,OAAO,EAAE,MAAM,EACf,KAAK,CAAC,EAAE,MAAM,GACb,MAAM,CAyBR"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateBrowserFingerprint = generateBrowserFingerprint;
4
+ /**
5
+ * Generate a fingerprint for browser errors (for error grouping).
6
+ * Uses SubtleCrypto for SHA-256 in the browser.
7
+ */
8
+ function generateBrowserFingerprint(message, stack) {
9
+ // Normalize dynamic values in message
10
+ let normalized = message
11
+ .replace(/\b[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}\b/gi, '<UUID>')
12
+ .replace(/\d+/g, '<N>')
13
+ .replace(/(https?:\/\/)[^\s]+/g, '<URL>');
14
+ // Extract top 3 stack frames (file:line only)
15
+ let stackKey = '';
16
+ if (stack) {
17
+ const lines = stack.split('\n').slice(1, 4);
18
+ stackKey = lines
19
+ .map((line) => {
20
+ const match = line.match(/(?:at\s+)?(.+?):(\d+):\d+/);
21
+ return match ? `${match[1]}:${match[2]}` : '';
22
+ })
23
+ .filter(Boolean)
24
+ .join('|');
25
+ }
26
+ const input = `${normalized}||${stackKey}`;
27
+ // Synchronous hash using simple djb2 + fnv mix for performance
28
+ // (SubtleCrypto is async and overkill for fingerprinting)
29
+ return simpleHash(input);
30
+ }
31
+ /**
32
+ * Fast, synchronous hash producing a 16-char hex string.
33
+ * Not cryptographic — just for grouping.
34
+ */
35
+ function simpleHash(str) {
36
+ let h1 = 0x811c9dc5; // FNV offset basis
37
+ let h2 = 0x1000193; // FNV prime seed
38
+ for (let i = 0; i < str.length; i++) {
39
+ const ch = str.charCodeAt(i);
40
+ // FNV-1a
41
+ h1 ^= ch;
42
+ h1 = Math.imul(h1, 0x01000193);
43
+ // djb2
44
+ h2 = ((h2 << 5) + h2 + ch) >>> 0;
45
+ }
46
+ return (h1 >>> 0).toString(16).padStart(8, '0') + (h2 >>> 0).toString(16).padStart(8, '0');
47
+ }
48
+ //# sourceMappingURL=fingerprint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.js","sourceRoot":"","sources":["../src/fingerprint.ts"],"names":[],"mappings":";;AAIA,gEA4BC;AAhCD;;;GAGG;AACH,SAAgB,0BAA0B,CACxC,OAAe,EACf,KAAc;IAEd,sCAAsC;IACtC,IAAI,UAAU,GAAG,OAAO;SACrB,OAAO,CAAC,oEAAoE,EAAE,QAAQ,CAAC;SACvF,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC;SACtB,OAAO,CAAC,sBAAsB,EAAE,OAAO,CAAC,CAAC;IAE5C,8CAA8C;IAC9C,IAAI,QAAQ,GAAG,EAAE,CAAC;IAClB,IAAI,KAAK,EAAE,CAAC;QACV,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5C,QAAQ,GAAG,KAAK;aACb,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;YACtD,OAAO,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAChD,CAAC,CAAC;aACD,MAAM,CAAC,OAAO,CAAC;aACf,IAAI,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IAED,MAAM,KAAK,GAAG,GAAG,UAAU,KAAK,QAAQ,EAAE,CAAC;IAE3C,+DAA+D;IAC/D,0DAA0D;IAC1D,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;AAC3B,CAAC;AAED;;;GAGG;AACH,SAAS,UAAU,CAAC,GAAW;IAC7B,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC,mBAAmB;IACxC,IAAI,EAAE,GAAG,SAAS,CAAC,CAAC,iBAAiB;IAErC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACpC,MAAM,EAAE,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC7B,SAAS;QACT,EAAE,IAAI,EAAE,CAAC;QACT,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QAC/B,OAAO;QACP,EAAE,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,OAAO,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7F,CAAC"}
@@ -0,0 +1,28 @@
1
+ import type { FrontendErrorEntry, Breadcrumb } from '@logcaffe/shared';
2
+ import type { UserContext } from './context.js';
3
+ import type { BrowserConfig } from './types.js';
4
+ export type { BrowserConfig } from './types.js';
5
+ export type { FrontendErrorEntry, Breadcrumb } from '@logcaffe/shared';
6
+ export type { UserContext } from './context.js';
7
+ export { LogCaffeErrorBoundary } from './react/ErrorBoundary.js';
8
+ export { getSessionId } from './context.js';
9
+ export { generateBrowserFingerprint } from './fingerprint.js';
10
+ declare class LogCaffeInstance {
11
+ private config;
12
+ private client;
13
+ private buffer;
14
+ private initialized;
15
+ init(config: BrowserConfig): void;
16
+ setUser(user: UserContext | null): void;
17
+ getUser(): UserContext | null;
18
+ addBreadcrumb(crumb: Omit<Breadcrumb, 'timestamp'> & {
19
+ timestamp?: number;
20
+ }): void;
21
+ error(message: string, meta?: Record<string, unknown>): void;
22
+ warn(message: string, meta?: Record<string, unknown>): void;
23
+ info(message: string, meta?: Record<string, unknown>): void;
24
+ captureError(entry: FrontendErrorEntry): void;
25
+ shutdown(): void;
26
+ }
27
+ export declare const LogCaffe: LogCaffeInstance;
28
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AASvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAUhD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAChD,YAAY,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACvE,YAAY,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,0BAA0B,EAAE,MAAM,kBAAkB,CAAC;AAE9D,cAAM,gBAAgB;IACpB,OAAO,CAAC,MAAM,CAA8B;IAC5C,OAAO,CAAC,MAAM,CAAkC;IAChD,OAAO,CAAC,MAAM,CAA8B;IAC5C,OAAO,CAAC,WAAW,CAAS;IAE5B,IAAI,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI;IA8EjC,OAAO,CAAC,IAAI,EAAE,WAAW,GAAG,IAAI,GAAG,IAAI;IAIvC,OAAO,IAAI,WAAW,GAAG,IAAI;IAM7B,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,GAAG;QAAE,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAMlF,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAc5D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAc3D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAgB3D,YAAY,CAAC,KAAK,EAAE,kBAAkB,GAAG,IAAI;IAW7C,QAAQ,IAAI,IAAI;CAiBjB;AAGD,eAAO,MAAM,QAAQ,kBAAyB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,156 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LogCaffe = exports.generateBrowserFingerprint = exports.getSessionId = exports.LogCaffeErrorBoundary = void 0;
4
+ const client_js_1 = require("./client.js");
5
+ const buffer_js_1 = require("./buffer.js");
6
+ const errors_js_1 = require("./collectors/errors.js");
7
+ const console_js_1 = require("./collectors/console.js");
8
+ const performance_js_1 = require("./collectors/performance.js");
9
+ const network_js_1 = require("./collectors/network.js");
10
+ const ErrorBoundary_js_1 = require("./react/ErrorBoundary.js");
11
+ const context_js_1 = require("./context.js");
12
+ const breadcrumbs_js_1 = require("./breadcrumbs.js");
13
+ var ErrorBoundary_js_2 = require("./react/ErrorBoundary.js");
14
+ Object.defineProperty(exports, "LogCaffeErrorBoundary", { enumerable: true, get: function () { return ErrorBoundary_js_2.LogCaffeErrorBoundary; } });
15
+ var context_js_2 = require("./context.js");
16
+ Object.defineProperty(exports, "getSessionId", { enumerable: true, get: function () { return context_js_2.getSessionId; } });
17
+ var fingerprint_js_1 = require("./fingerprint.js");
18
+ Object.defineProperty(exports, "generateBrowserFingerprint", { enumerable: true, get: function () { return fingerprint_js_1.generateBrowserFingerprint; } });
19
+ class LogCaffeInstance {
20
+ config = null;
21
+ client = null;
22
+ buffer = null;
23
+ initialized = false;
24
+ init(config) {
25
+ if (this.initialized) {
26
+ this.shutdown();
27
+ }
28
+ this.config = {
29
+ environment: 'production',
30
+ captureErrors: true,
31
+ captureRejections: true,
32
+ captureConsole: false,
33
+ capturePerformance: true,
34
+ captureNetwork: true,
35
+ captureBreadcrumbs: true,
36
+ captureNavigation: true,
37
+ captureDom: false,
38
+ maxBreadcrumbs: 20,
39
+ flushInterval: 10000,
40
+ maxBatchSize: 50,
41
+ ...config,
42
+ };
43
+ this.client = new client_js_1.BrowserHttpClient(this.config.serverUrl, this.config.apiKey);
44
+ this.buffer = new buffer_js_1.BrowserBuffer(this.client, this.config.flushInterval, this.config.maxBatchSize, this.config.beforeSend);
45
+ // Setup breadcrumb capture
46
+ if (this.config.captureBreadcrumbs) {
47
+ (0, breadcrumbs_js_1.setMaxBreadcrumbs)(this.config.maxBreadcrumbs);
48
+ (0, breadcrumbs_js_1.startClickCapture)();
49
+ if (this.config.captureNavigation) {
50
+ (0, breadcrumbs_js_1.startNavigationCapture)();
51
+ }
52
+ }
53
+ // Setup error capture (window.onerror + unhandledrejection)
54
+ (0, errors_js_1.setupErrorCapture)(this.buffer, this.config);
55
+ // Console interception
56
+ if (this.config.captureConsole) {
57
+ (0, console_js_1.interceptConsole)(this.buffer);
58
+ }
59
+ // Performance metrics
60
+ if (this.config.capturePerformance) {
61
+ (0, performance_js_1.collectPerformanceMetrics)(this.buffer);
62
+ }
63
+ // Network error detection
64
+ if (this.config.captureNetwork) {
65
+ (0, network_js_1.interceptNetwork)(this.buffer);
66
+ }
67
+ // Set up React ErrorBoundary callback
68
+ (0, ErrorBoundary_js_1.setCaptureCallback)((entry) => this.captureError(entry));
69
+ // Flush on page unload
70
+ window.addEventListener('visibilitychange', () => {
71
+ if (document.visibilityState === 'hidden' && this.buffer) {
72
+ this.buffer.flushSync();
73
+ }
74
+ });
75
+ window.addEventListener('beforeunload', () => {
76
+ if (this.buffer) {
77
+ this.buffer.flushSync();
78
+ }
79
+ });
80
+ this.initialized = true;
81
+ }
82
+ // ─── User Context ───
83
+ setUser(user) {
84
+ (0, context_js_1.setUser)(user);
85
+ }
86
+ getUser() {
87
+ return (0, context_js_1.getUser)();
88
+ }
89
+ // ─── Breadcrumbs ───
90
+ addBreadcrumb(crumb) {
91
+ (0, breadcrumbs_js_1.addBreadcrumb)({ ...crumb, timestamp: crumb.timestamp ?? Date.now() });
92
+ }
93
+ // ─── Manual Logging ───
94
+ error(message, meta) {
95
+ if (!this.buffer || !this.config)
96
+ return;
97
+ const entry = (0, errors_js_1.enrichEntry)({
98
+ message,
99
+ url: window.location.href,
100
+ userAgent: navigator.userAgent,
101
+ meta: { ...meta, level: 'ERROR' },
102
+ }, this.config);
103
+ this.buffer.add(entry);
104
+ }
105
+ warn(message, meta) {
106
+ if (!this.buffer || !this.config)
107
+ return;
108
+ const entry = (0, errors_js_1.enrichEntry)({
109
+ message,
110
+ url: window.location.href,
111
+ userAgent: navigator.userAgent,
112
+ meta: { ...meta, level: 'WARN' },
113
+ }, this.config);
114
+ this.buffer.add(entry);
115
+ }
116
+ info(message, meta) {
117
+ if (!this.buffer || !this.config)
118
+ return;
119
+ const entry = (0, errors_js_1.enrichEntry)({
120
+ message,
121
+ url: window.location.href,
122
+ userAgent: navigator.userAgent,
123
+ meta: { ...meta, level: 'INFO' },
124
+ }, this.config);
125
+ this.buffer.add(entry);
126
+ }
127
+ // ─── Direct Error Capture ───
128
+ captureError(entry) {
129
+ if (!this.buffer || !this.config)
130
+ return;
131
+ // Enrich if not already enriched (no fingerprint = not enriched)
132
+ if (!entry.fingerprint) {
133
+ entry = (0, errors_js_1.enrichEntry)(entry, this.config);
134
+ }
135
+ this.buffer.add(entry);
136
+ }
137
+ // ─── Shutdown ───
138
+ shutdown() {
139
+ if (!this.initialized)
140
+ return;
141
+ (0, errors_js_1.removeErrorCapture)();
142
+ (0, console_js_1.restoreConsole)();
143
+ (0, network_js_1.restoreNetwork)();
144
+ (0, ErrorBoundary_js_1.clearCaptureCallback)();
145
+ (0, breadcrumbs_js_1.stopClickCapture)();
146
+ (0, breadcrumbs_js_1.stopNavigationCapture)();
147
+ (0, breadcrumbs_js_1.clearBreadcrumbs)();
148
+ if (this.buffer) {
149
+ this.buffer.shutdown();
150
+ }
151
+ this.initialized = false;
152
+ }
153
+ }
154
+ // Singleton export
155
+ exports.LogCaffe = new LogCaffeInstance();
156
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AACA,2CAAgD;AAChD,2CAA4C;AAC5C,sDAA4F;AAC5F,wDAA2E;AAC3E,gEAAwE;AACxE,wDAA2E;AAC3E,+DAAoF;AACpF,6CAA4E;AAE5E,qDAQ0B;AAM1B,6DAAiE;AAAxD,yHAAA,qBAAqB,OAAA;AAC9B,2CAA4C;AAAnC,0GAAA,YAAY,OAAA;AACrB,mDAA8D;AAArD,4HAAA,0BAA0B,OAAA;AAEnC,MAAM,gBAAgB;IACZ,MAAM,GAAyB,IAAI,CAAC;IACpC,MAAM,GAA6B,IAAI,CAAC;IACxC,MAAM,GAAyB,IAAI,CAAC;IACpC,WAAW,GAAG,KAAK,CAAC;IAE5B,IAAI,CAAC,MAAqB;QACxB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,QAAQ,EAAE,CAAC;QAClB,CAAC;QAED,IAAI,CAAC,MAAM,GAAG;YACZ,WAAW,EAAE,YAAY;YACzB,aAAa,EAAE,IAAI;YACnB,iBAAiB,EAAE,IAAI;YACvB,cAAc,EAAE,KAAK;YACrB,kBAAkB,EAAE,IAAI;YACxB,cAAc,EAAE,IAAI;YACpB,kBAAkB,EAAE,IAAI;YACxB,iBAAiB,EAAE,IAAI;YACvB,UAAU,EAAE,KAAK;YACjB,cAAc,EAAE,EAAE;YAClB,aAAa,EAAE,KAAK;YACpB,YAAY,EAAE,EAAE;YAChB,GAAG,MAAM;SACV,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,IAAI,6BAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC/E,IAAI,CAAC,MAAM,GAAG,IAAI,yBAAa,CAC7B,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,CAAC,aAAc,EAC1B,IAAI,CAAC,MAAM,CAAC,YAAa,EACzB,IAAI,CAAC,MAAM,CAAC,UAAU,CACvB,CAAC;QAEF,2BAA2B;QAC3B,IAAI,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC;YACnC,IAAA,kCAAiB,EAAC,IAAI,CAAC,MAAM,CAAC,cAAe,CAAC,CAAC;YAC/C,IAAA,kCAAiB,GAAE,CAAC;YAEpB,IAAI,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC;gBAClC,IAAA,uCAAsB,GAAE,CAAC;YAC3B,CAAC;QACH,CAAC;QAED,4DAA4D;QAC5D,IAAA,6BAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE5C,uBAAuB;QACvB,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YAC/B,IAAA,6BAAgB,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,sBAAsB;QACtB,IAAI,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC;YACnC,IAAA,0CAAyB,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC;QAED,0BAA0B;QAC1B,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;YAC/B,IAAA,6BAAgB,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,sCAAsC;QACtC,IAAA,qCAAkB,EAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;QAExD,uBAAuB;QACvB,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,GAAG,EAAE;YAC/C,IAAI,QAAQ,CAAC,eAAe,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBACzD,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,cAAc,EAAE,GAAG,EAAE;YAC3C,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YAC1B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,uBAAuB;IAEvB,OAAO,CAAC,IAAwB;QAC9B,IAAA,oBAAU,EAAC,IAAI,CAAC,CAAC;IACnB,CAAC;IAED,OAAO;QACL,OAAO,IAAA,oBAAU,GAAE,CAAC;IACtB,CAAC;IAED,sBAAsB;IAEtB,aAAa,CAAC,KAA6D;QACzE,IAAA,8BAAQ,EAAC,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,GAAG,EAAE,EAAgB,CAAC,CAAC;IACjF,CAAC;IAED,yBAAyB;IAEzB,KAAK,CAAC,OAAe,EAAE,IAA8B;QACnD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QACzC,MAAM,KAAK,GAAG,IAAA,uBAAW,EACvB;YACE,OAAO;YACP,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;YACzB,SAAS,EAAE,SAAS,CAAC,SAAS;YAC9B,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE;SAClC,EACD,IAAI,CAAC,MAAM,CACZ,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,IAA8B;QAClD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QACzC,MAAM,KAAK,GAAG,IAAA,uBAAW,EACvB;YACE,OAAO;YACP,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;YACzB,SAAS,EAAE,SAAS,CAAC,SAAS;YAC9B,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;SACjC,EACD,IAAI,CAAC,MAAM,CACZ,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,OAAe,EAAE,IAA8B;QAClD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QACzC,MAAM,KAAK,GAAG,IAAA,uBAAW,EACvB;YACE,OAAO;YACP,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;YACzB,SAAS,EAAE,SAAS,CAAC,SAAS;YAC9B,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE;SACjC,EACD,IAAI,CAAC,MAAM,CACZ,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,+BAA+B;IAE/B,YAAY,CAAC,KAAyB;QACpC,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QACzC,iEAAiE;QACjE,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;YACvB,KAAK,GAAG,IAAA,uBAAW,EAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED,mBAAmB;IAEnB,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO;QAE9B,IAAA,8BAAkB,GAAE,CAAC;QACrB,IAAA,2BAAc,GAAE,CAAC;QACjB,IAAA,2BAAc,GAAE,CAAC;QACjB,IAAA,uCAAoB,GAAE,CAAC;QACvB,IAAA,iCAAgB,GAAE,CAAC;QACnB,IAAA,sCAAqB,GAAE,CAAC;QACxB,IAAA,iCAAgB,GAAE,CAAC;QAEnB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;CACF;AAED,mBAAmB;AACN,QAAA,QAAQ,GAAG,IAAI,gBAAgB,EAAE,CAAC"}
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import type { FrontendErrorEntry } from '@logcaffe/shared';
3
+ interface ErrorBoundaryProps {
4
+ children: React.ReactNode;
5
+ fallback?: React.ReactNode;
6
+ onError?: (error: Error, errorInfo: React.ErrorInfo) => void;
7
+ }
8
+ interface ErrorBoundaryState {
9
+ hasError: boolean;
10
+ error?: Error;
11
+ }
12
+ export declare function setCaptureCallback(cb: (entry: FrontendErrorEntry) => void): void;
13
+ export declare function clearCaptureCallback(): void;
14
+ export declare class LogCaffeErrorBoundary extends React.Component<ErrorBoundaryProps, ErrorBoundaryState> {
15
+ state: ErrorBoundaryState;
16
+ static getDerivedStateFromError(error: Error): ErrorBoundaryState;
17
+ componentDidCatch(error: Error, errorInfo: React.ErrorInfo): void;
18
+ render(): React.ReactNode;
19
+ }
20
+ export {};
21
+ //# sourceMappingURL=ErrorBoundary.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorBoundary.d.ts","sourceRoot":"","sources":["../../src/react/ErrorBoundary.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAE3D,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC;CAC9D;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,CAAC;CACf;AAKD,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,kBAAkB,KAAK,IAAI,GAAG,IAAI,CAEhF;AAED,wBAAgB,oBAAoB,IAAI,IAAI,CAE3C;AAED,qBAAa,qBAAsB,SAAQ,KAAK,CAAC,SAAS,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;IAChG,KAAK,EAAE,kBAAkB,CAAuB;IAEhD,MAAM,CAAC,wBAAwB,CAAC,KAAK,EAAE,KAAK,GAAG,kBAAkB;IAIjE,iBAAiB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS;IAc1D,MAAM;CAMP"}
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.LogCaffeErrorBoundary = void 0;
7
+ exports.setCaptureCallback = setCaptureCallback;
8
+ exports.clearCaptureCallback = clearCaptureCallback;
9
+ const react_1 = __importDefault(require("react"));
10
+ // Callback set by LogCaffe.init() to capture errors
11
+ let captureCallback = null;
12
+ function setCaptureCallback(cb) {
13
+ captureCallback = cb;
14
+ }
15
+ function clearCaptureCallback() {
16
+ captureCallback = null;
17
+ }
18
+ class LogCaffeErrorBoundary extends react_1.default.Component {
19
+ state = { hasError: false };
20
+ static getDerivedStateFromError(error) {
21
+ return { hasError: true, error };
22
+ }
23
+ componentDidCatch(error, errorInfo) {
24
+ if (captureCallback) {
25
+ captureCallback({
26
+ message: error.message,
27
+ stack: error.stack,
28
+ componentStack: errorInfo.componentStack ?? undefined,
29
+ url: window.location.href,
30
+ userAgent: navigator.userAgent,
31
+ });
32
+ }
33
+ this.props.onError?.(error, errorInfo);
34
+ }
35
+ render() {
36
+ if (this.state.hasError) {
37
+ return this.props.fallback ?? react_1.default.createElement('h1', null, 'Something went wrong');
38
+ }
39
+ return this.props.children;
40
+ }
41
+ }
42
+ exports.LogCaffeErrorBoundary = LogCaffeErrorBoundary;
43
+ //# sourceMappingURL=ErrorBoundary.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ErrorBoundary.js","sourceRoot":"","sources":["../../src/react/ErrorBoundary.tsx"],"names":[],"mappings":";;;;;;AAiBA,gDAEC;AAED,oDAEC;AAvBD,kDAA0B;AAc1B,oDAAoD;AACpD,IAAI,eAAe,GAAiD,IAAI,CAAC;AAEzE,SAAgB,kBAAkB,CAAC,EAAuC;IACxE,eAAe,GAAG,EAAE,CAAC;AACvB,CAAC;AAED,SAAgB,oBAAoB;IAClC,eAAe,GAAG,IAAI,CAAC;AACzB,CAAC;AAED,MAAa,qBAAsB,SAAQ,eAAK,CAAC,SAAiD;IAChG,KAAK,GAAuB,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IAEhD,MAAM,CAAC,wBAAwB,CAAC,KAAY;QAC1C,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,KAAY,EAAE,SAA0B;QACxD,IAAI,eAAe,EAAE,CAAC;YACpB,eAAe,CAAC;gBACd,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,cAAc,EAAE,SAAS,CAAC,cAAc,IAAI,SAAS;gBACrD,GAAG,EAAE,MAAM,CAAC,QAAQ,CAAC,IAAI;gBACzB,SAAS,EAAE,SAAS,CAAC,SAAS;aAC/B,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACzC,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,eAAK,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,sBAAsB,CAAC,CAAC;QACxF,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;CACF;AA3BD,sDA2BC"}
@@ -0,0 +1,25 @@
1
+ import type { FrontendErrorEntry } from '@logcaffe/shared';
2
+ export interface BrowserConfig {
3
+ serverUrl: string;
4
+ apiKey: string;
5
+ environment?: string;
6
+ captureErrors?: boolean;
7
+ captureRejections?: boolean;
8
+ captureConsole?: boolean;
9
+ capturePerformance?: boolean;
10
+ captureNetwork?: boolean;
11
+ release?: string;
12
+ captureBreadcrumbs?: boolean;
13
+ maxBreadcrumbs?: number;
14
+ captureDom?: boolean;
15
+ captureNavigation?: boolean;
16
+ defaultTags?: string[];
17
+ flushInterval?: number;
18
+ maxBatchSize?: number;
19
+ sanitizeHeaders?: string[];
20
+ sanitizeBodyKeys?: string[];
21
+ ignoreErrors?: (string | RegExp)[];
22
+ ignoreUrls?: (string | RegExp)[];
23
+ beforeSend?: (error: FrontendErrorEntry) => FrontendErrorEntry | null;
24
+ }
25
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAE3D,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IAGrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,cAAc,CAAC,EAAE,OAAO,CAAC;IAGzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IAGvB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;IAGtB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;IAG5B,YAAY,CAAC,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;IACnC,UAAU,CAAC,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAC;IACjC,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,kBAAkB,KAAK,kBAAkB,GAAG,IAAI,CAAC;CACvE"}
package/dist/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":""}
package/package.json ADDED
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "@logcaffe/browser",
3
+ "version": "0.3.2",
4
+ "description": "Browser SDK for LogCaffe - capture frontend errors & performance",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "dist"
9
+ ],
10
+ "scripts": {
11
+ "build": "tsc",
12
+ "dev": "tsc --watch"
13
+ },
14
+ "publishConfig": {
15
+ "access": "public",
16
+ "registry": "https://registry.npmjs.org/"
17
+ },
18
+ "repository": {
19
+ "type": "git",
20
+ "url": "https://github.com/logcaffe/LogCaffe.git"
21
+ },
22
+ "dependencies": {
23
+ "@logcaffe/shared": "^0.3.0"
24
+ },
25
+ "peerDependencies": {
26
+ "react": ">=16.8.0"
27
+ },
28
+ "peerDependenciesMeta": {
29
+ "react": {
30
+ "optional": true
31
+ }
32
+ },
33
+ "devDependencies": {
34
+ "@types/react": "^18.0.0",
35
+ "react": "^18.0.0",
36
+ "typescript": "^5.4.0"
37
+ }
38
+ }