@sentry/react-native 6.14.0 → 6.15.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 (96) hide show
  1. package/RNSentry.podspec +1 -1
  2. package/android/src/main/java/io/sentry/react/RNSentryModuleImpl.java +10 -0
  3. package/android/src/main/java/io/sentry/react/RNSentryVersion.java +1 -1
  4. package/android/src/newarch/java/io/sentry/react/RNSentryModule.java +5 -0
  5. package/android/src/oldarch/java/io/sentry/react/RNSentryModule.java +5 -0
  6. package/dist/js/NativeRNSentry.d.ts +1 -0
  7. package/dist/js/NativeRNSentry.d.ts.map +1 -1
  8. package/dist/js/NativeRNSentry.js.map +1 -1
  9. package/dist/js/feedback/FeedbackButton.d.ts +23 -0
  10. package/dist/js/feedback/FeedbackButton.d.ts.map +1 -0
  11. package/dist/js/feedback/FeedbackButton.js +51 -0
  12. package/dist/js/feedback/FeedbackButton.js.map +1 -0
  13. package/dist/js/feedback/FeedbackWidget.d.ts +12 -1
  14. package/dist/js/feedback/FeedbackWidget.d.ts.map +1 -1
  15. package/dist/js/feedback/FeedbackWidget.js +78 -13
  16. package/dist/js/feedback/FeedbackWidget.js.map +1 -1
  17. package/dist/js/feedback/FeedbackWidget.styles.d.ts +6 -3
  18. package/dist/js/feedback/FeedbackWidget.styles.d.ts.map +1 -1
  19. package/dist/js/feedback/FeedbackWidget.styles.js +155 -106
  20. package/dist/js/feedback/FeedbackWidget.styles.js.map +1 -1
  21. package/dist/js/feedback/FeedbackWidget.theme.d.ts +37 -0
  22. package/dist/js/feedback/FeedbackWidget.theme.d.ts.map +1 -0
  23. package/dist/js/feedback/FeedbackWidget.theme.js +31 -0
  24. package/dist/js/feedback/FeedbackWidget.theme.js.map +1 -0
  25. package/dist/js/feedback/FeedbackWidget.types.d.ts +71 -2
  26. package/dist/js/feedback/FeedbackWidget.types.d.ts.map +1 -1
  27. package/dist/js/feedback/FeedbackWidget.types.js.map +1 -1
  28. package/dist/js/feedback/FeedbackWidgetManager.d.ts +43 -23
  29. package/dist/js/feedback/FeedbackWidgetManager.d.ts.map +1 -1
  30. package/dist/js/feedback/FeedbackWidgetManager.js +62 -138
  31. package/dist/js/feedback/FeedbackWidgetManager.js.map +1 -1
  32. package/dist/js/feedback/FeedbackWidgetProvider.d.ts +48 -0
  33. package/dist/js/feedback/FeedbackWidgetProvider.d.ts.map +1 -0
  34. package/dist/js/feedback/FeedbackWidgetProvider.js +177 -0
  35. package/dist/js/feedback/FeedbackWidgetProvider.js.map +1 -0
  36. package/dist/js/feedback/ScreenshotButton.d.ts +25 -0
  37. package/dist/js/feedback/ScreenshotButton.d.ts.map +1 -0
  38. package/dist/js/feedback/ScreenshotButton.js +80 -0
  39. package/dist/js/feedback/ScreenshotButton.js.map +1 -0
  40. package/dist/js/feedback/defaults.d.ts +3 -1
  41. package/dist/js/feedback/defaults.d.ts.map +1 -1
  42. package/dist/js/feedback/defaults.js +15 -0
  43. package/dist/js/feedback/defaults.js.map +1 -1
  44. package/dist/js/feedback/icons.d.ts +30 -0
  45. package/dist/js/feedback/icons.d.ts.map +1 -0
  46. package/dist/js/feedback/icons.js +30 -0
  47. package/dist/js/feedback/icons.js.map +1 -0
  48. package/dist/js/feedback/integration.d.ts +19 -2
  49. package/dist/js/feedback/integration.d.ts.map +1 -1
  50. package/dist/js/feedback/integration.js +58 -3
  51. package/dist/js/feedback/integration.js.map +1 -1
  52. package/dist/js/feedback/lazy.d.ts +10 -0
  53. package/dist/js/feedback/lazy.d.ts.map +1 -1
  54. package/dist/js/feedback/lazy.js +24 -0
  55. package/dist/js/feedback/lazy.js.map +1 -1
  56. package/dist/js/index.d.ts +3 -2
  57. package/dist/js/index.d.ts.map +1 -1
  58. package/dist/js/index.js +2 -1
  59. package/dist/js/index.js.map +1 -1
  60. package/dist/js/integrations/reactnativeerrorhandlers.d.ts.map +1 -1
  61. package/dist/js/integrations/reactnativeerrorhandlers.js +65 -31
  62. package/dist/js/integrations/reactnativeerrorhandlers.js.map +1 -1
  63. package/dist/js/sdk.js +1 -1
  64. package/dist/js/sdk.js.map +1 -1
  65. package/dist/js/utils/worldwide.d.ts +7 -0
  66. package/dist/js/utils/worldwide.d.ts.map +1 -1
  67. package/dist/js/utils/worldwide.js.map +1 -1
  68. package/dist/js/version.d.ts +1 -1
  69. package/dist/js/version.js +1 -1
  70. package/dist/js/version.js.map +1 -1
  71. package/dist/js/wrapper.d.ts +1 -0
  72. package/dist/js/wrapper.d.ts.map +1 -1
  73. package/dist/js/wrapper.js +17 -1
  74. package/dist/js/wrapper.js.map +1 -1
  75. package/ios/RNSentry.mm +24 -0
  76. package/ios/RNSentryOnDrawReporter.m +4 -0
  77. package/ios/RNSentryVersion.m +1 -1
  78. package/package.json +4 -4
  79. package/src/js/NativeRNSentry.ts +1 -0
  80. package/ts3.8/dist/js/NativeRNSentry.d.ts +1 -0
  81. package/ts3.8/dist/js/feedback/FeedbackButton.d.ts +23 -0
  82. package/ts3.8/dist/js/feedback/FeedbackWidget.d.ts +12 -1
  83. package/ts3.8/dist/js/feedback/FeedbackWidget.styles.d.ts +6 -3
  84. package/ts3.8/dist/js/feedback/FeedbackWidget.theme.d.ts +37 -0
  85. package/ts3.8/dist/js/feedback/FeedbackWidget.types.d.ts +71 -2
  86. package/ts3.8/dist/js/feedback/FeedbackWidgetManager.d.ts +43 -23
  87. package/ts3.8/dist/js/feedback/FeedbackWidgetProvider.d.ts +48 -0
  88. package/ts3.8/dist/js/feedback/ScreenshotButton.d.ts +25 -0
  89. package/ts3.8/dist/js/feedback/defaults.d.ts +3 -1
  90. package/ts3.8/dist/js/feedback/icons.d.ts +30 -0
  91. package/ts3.8/dist/js/feedback/integration.d.ts +19 -2
  92. package/ts3.8/dist/js/feedback/lazy.d.ts +10 -0
  93. package/ts3.8/dist/js/index.d.ts +3 -2
  94. package/ts3.8/dist/js/utils/worldwide.d.ts +7 -0
  95. package/ts3.8/dist/js/version.d.ts +1 -1
  96. package/ts3.8/dist/js/wrapper.d.ts +1 -0
@@ -0,0 +1,48 @@
1
+ import * as React from 'react';
2
+ import { Animated } from 'react-native';
3
+ import type { FeedbackWidgetStyles } from './FeedbackWidget.types';
4
+ export interface FeedbackWidgetProviderProps {
5
+ children: React.ReactNode;
6
+ styles?: FeedbackWidgetStyles;
7
+ }
8
+ export interface FeedbackWidgetProviderState {
9
+ isButtonVisible: boolean;
10
+ isScreenshotButtonVisible: boolean;
11
+ isVisible: boolean;
12
+ backgroundOpacity: Animated.Value;
13
+ panY: Animated.Value;
14
+ isScrollAtTop: boolean;
15
+ }
16
+ /**
17
+ * FeedbackWidgetProvider is a component that wraps the feedback widget and provides
18
+ * functionality to show and hide the widget. It also manages the visibility of the
19
+ * feedback button and screenshot button.
20
+ */
21
+ export declare class FeedbackWidgetProvider extends React.Component<FeedbackWidgetProviderProps> {
22
+ state: FeedbackWidgetProviderState;
23
+ private _themeListener;
24
+ private _panResponder;
25
+ constructor(props: FeedbackWidgetProviderProps);
26
+ /**
27
+ * Add a listener to the theme change event.
28
+ */
29
+ componentDidMount(): void;
30
+ /**
31
+ * Clean up the theme listener.
32
+ */
33
+ componentWillUnmount(): void;
34
+ /**
35
+ * Animates the background opacity when the modal is shown.
36
+ */
37
+ componentDidUpdate(_prevProps: any, prevState: FeedbackWidgetProviderState): void;
38
+ /**
39
+ * Renders the feedback form modal.
40
+ */
41
+ render(): React.ReactNode;
42
+ private _handleScroll;
43
+ private _setVisibilityFunction;
44
+ private _setButtonVisibilityFunction;
45
+ private _setScreenshotButtonVisibilityFunction;
46
+ private _handleClose;
47
+ }
48
+ //# sourceMappingURL=FeedbackWidgetProvider.d.ts.map
@@ -0,0 +1,25 @@
1
+ import * as React from 'react';
2
+ import type { Screenshot } from '../wrapper';
3
+ import type { ScreenshotButtonProps } from './FeedbackWidget.types';
4
+ export declare const getCapturedScreenshot: () => Screenshot | 'ErrorCapturingScreenshot' | undefined;
5
+ /**
6
+ * @beta
7
+ * Implements a screenshot button that takes a screenshot.
8
+ */
9
+ export declare class ScreenshotButton extends React.Component<ScreenshotButtonProps> {
10
+ private _themeListener;
11
+ constructor(props: ScreenshotButtonProps);
12
+ /**
13
+ * Adds a listener for theme changes.
14
+ */
15
+ componentDidMount(): void;
16
+ /**
17
+ * Removes the theme listener.
18
+ */
19
+ componentWillUnmount(): void;
20
+ /**
21
+ * Renders the screenshot button.
22
+ */
23
+ render(): React.ReactNode;
24
+ }
25
+ //# sourceMappingURL=ScreenshotButton.d.ts.map
@@ -1,3 +1,5 @@
1
- import type { FeedbackWidgetProps } from './FeedbackWidget.types';
1
+ import type { FeedbackButtonProps, FeedbackWidgetProps, ScreenshotButtonProps } from './FeedbackWidget.types';
2
2
  export declare const defaultConfiguration: Partial<FeedbackWidgetProps>;
3
+ export declare const defaultButtonConfiguration: Partial<FeedbackButtonProps>;
4
+ export declare const defaultScreenshotButtonConfiguration: Partial<ScreenshotButtonProps>;
3
5
  //# sourceMappingURL=defaults.d.ts.map
@@ -0,0 +1,30 @@
1
+ export declare const feedbackIcon = "";
2
+ /**
3
+ * Source: https://github.com/tabler/tabler-icons/blob/b54c86433ed5121e2590bf09f0faf746bb5aba66/icons/outline/screenshot.svg
4
+ *
5
+ * MIT License
6
+ *
7
+ * Copyright (c) 2020-2024 Paweł Kuna
8
+ *
9
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
10
+ * of this software and associated documentation files (the "Software"), to deal
11
+ * in the Software without restriction, including without limitation the rights
12
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13
+ * copies of the Software, and to permit persons to whom the Software is
14
+ * furnished to do so, subject to the following conditions:
15
+ *
16
+ * The above copyright notice and this permission notice shall be included in all
17
+ * copies or substantial portions of the Software.
18
+ *
19
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
25
+ * SOFTWARE.
26
+ *
27
+ * TODO: Replace with another screenshot icon when available
28
+ */
29
+ export declare const screenshotIcon = "";
30
+ //# sourceMappingURL=icons.d.ts.map
@@ -1,10 +1,27 @@
1
1
  import type { Integration } from '@sentry/core';
2
- import type { FeedbackWidgetProps } from './FeedbackWidget.types';
2
+ import type { FeedbackWidgetTheme } from './FeedbackWidget.theme';
3
+ import type { FeedbackButtonProps, FeedbackWidgetProps, ScreenshotButtonProps } from './FeedbackWidget.types';
3
4
  export declare const MOBILE_FEEDBACK_INTEGRATION_NAME = "MobileFeedback";
4
5
  type FeedbackIntegration = Integration & {
5
6
  options: Partial<FeedbackWidgetProps>;
7
+ buttonOptions: Partial<FeedbackButtonProps>;
8
+ screenshotButtonOptions: Partial<ScreenshotButtonProps>;
9
+ colorScheme?: 'system' | 'light' | 'dark';
10
+ themeLight: Partial<FeedbackWidgetTheme>;
11
+ themeDark: Partial<FeedbackWidgetTheme>;
6
12
  };
7
- export declare const feedbackIntegration: (initOptions?: FeedbackWidgetProps) => FeedbackIntegration;
13
+ export declare const feedbackIntegration: (initOptions?: FeedbackWidgetProps & {
14
+ buttonOptions?: FeedbackButtonProps;
15
+ screenshotButtonOptions?: ScreenshotButtonProps;
16
+ colorScheme?: 'system' | 'light' | 'dark';
17
+ themeLight?: Partial<FeedbackWidgetTheme>;
18
+ themeDark?: Partial<FeedbackWidgetTheme>;
19
+ }) => FeedbackIntegration;
8
20
  export declare const getFeedbackOptions: () => Partial<FeedbackWidgetProps>;
21
+ export declare const getFeedbackButtonOptions: () => Partial<FeedbackButtonProps>;
22
+ export declare const getScreenshotButtonOptions: () => Partial<ScreenshotButtonProps>;
23
+ export declare const getColorScheme: () => 'system' | 'light' | 'dark';
24
+ export declare const getFeedbackLightTheme: () => Partial<FeedbackWidgetTheme>;
25
+ export declare const getFeedbackDarkTheme: () => Partial<FeedbackWidgetTheme>;
9
26
  export {};
10
27
  //# sourceMappingURL=integration.d.ts.map
@@ -7,4 +7,14 @@ export declare const AUTO_INJECT_FEEDBACK_INTEGRATION_NAME = "AutoInjectMobileFe
7
7
  * Lazy loads the auto inject feedback integration if it is not already loaded.
8
8
  */
9
9
  export declare function lazyLoadAutoInjectFeedbackIntegration(): void;
10
+ export declare const AUTO_INJECT_FEEDBACK_BUTTON_INTEGRATION_NAME = "AutoInjectMobileFeedbackButton";
11
+ /**
12
+ * Lazy loads the auto inject feedback button integration if it is not already loaded.
13
+ */
14
+ export declare function lazyLoadAutoInjectFeedbackButtonIntegration(): void;
15
+ export declare const AUTO_INJECT_SCREENSHOT_BUTTON_INTEGRATION_NAME = "AutoInjectMobileScreenshotButton";
16
+ /**
17
+ * Lazy loads the auto inject screenshot button integration if it is not already loaded.
18
+ */
19
+ export declare function lazyLoadAutoInjectScreenshotButtonIntegration(): void;
10
20
  //# sourceMappingURL=lazy.d.ts.map
@@ -1,4 +1,4 @@
1
- export type { Breadcrumb, Request, SdkInfo, Event, Exception, SendFeedbackParams, SeverityLevel, Span, StackFrame, Stacktrace, Thread, User, UserFeedback, } from '@sentry/core';
1
+ export type { Breadcrumb, Request, SdkInfo, Event, Exception, SendFeedbackParams, SeverityLevel, Span, StackFrame, Stacktrace, Thread, User, UserFeedback, ErrorEvent, TransactionEvent, } from '@sentry/core';
2
2
  export { addBreadcrumb, captureException, captureEvent, captureFeedback, captureMessage, Scope, setContext, setExtra, setExtras, setTag, setTags, setUser, startInactiveSpan, startSpan, startSpanManual, getActiveSpan, getRootSpan, withActiveSpan, suppressTracing, spanToJSON, spanIsSampled, setMeasurement, getCurrentScope, getGlobalScope, getIsolationScope, getClient, setCurrentClient, addEventProcessor, metricsDefault as metrics, lastEventId, } from '@sentry/core';
3
3
  export { ErrorBoundary, withErrorBoundary, createReduxEnhancer, Profiler, useProfiler, withProfiler, } from '@sentry/react';
4
4
  export * from './integrations/exports';
@@ -10,7 +10,8 @@ export { TouchEventBoundary, withTouchEventBoundary } from './touchevents';
10
10
  export { reactNativeTracingIntegration, getCurrentReactNativeTracingIntegration, getReactNativeTracingIntegration, reactNavigationIntegration, reactNativeNavigationIntegration, sentryTraceGesture, TimeToInitialDisplay, TimeToFullDisplay, startTimeToInitialDisplaySpan, startTimeToFullDisplaySpan, startIdleNavigationSpan, startIdleSpan, getDefaultIdleNavigationSpanOptions, createTimeToFullDisplay, createTimeToInitialDisplay, } from './tracing';
11
11
  export type { TimeToDisplayProps } from './tracing';
12
12
  export { Mask, Unmask } from './replay/CustomMask';
13
+ export { FeedbackButton } from './feedback/FeedbackButton';
13
14
  export { FeedbackWidget } from './feedback/FeedbackWidget';
14
- export { showFeedbackWidget } from './feedback/FeedbackWidgetManager';
15
+ export { showFeedbackWidget, showFeedbackButton, hideFeedbackButton } from './feedback/FeedbackWidgetManager';
15
16
  export { getDataFromUri } from './wrapper';
16
17
  //# sourceMappingURL=index.d.ts.map
@@ -2,12 +2,19 @@
2
2
  import type { InternalGlobal } from '@sentry/core';
3
3
  import type { ErrorUtils } from 'react-native/types';
4
4
  import type { ExpoGlobalObject } from './expoglobalobject';
5
+ export interface HermesPromiseRejectionTrackingOptions {
6
+ allRejections: boolean;
7
+ onUnhandled: (id: string, error: unknown) => void;
8
+ onHandled: (id: string) => void;
9
+ }
5
10
  /** Internal Global object interface with common and Sentry specific properties */
6
11
  export interface ReactNativeInternalGlobal extends InternalGlobal {
7
12
  __sentry_rn_v4_registered?: boolean;
8
13
  __sentry_rn_v5_registered?: boolean;
9
14
  HermesInternal?: {
10
15
  getRuntimeProperties?: () => Record<string, string | undefined>;
16
+ enablePromiseRejectionTracker?: (options: HermesPromiseRejectionTrackingOptions) => void;
17
+ hasPromise?: () => boolean;
11
18
  };
12
19
  Promise: unknown;
13
20
  __turboModuleProxy: unknown;
@@ -1,4 +1,4 @@
1
1
  export declare const SDK_PACKAGE_NAME = "npm:@sentry/react-native";
2
2
  export declare const SDK_NAME = "sentry.javascript.react-native";
3
- export declare const SDK_VERSION = "6.14.0";
3
+ export declare const SDK_VERSION = "6.15.0";
4
4
  //# sourceMappingURL=version.d.ts.map
@@ -77,6 +77,7 @@ interface SentryNativeWrapper {
77
77
  getDataFromUri(uri: string): Promise<Uint8Array | null>;
78
78
  popTimeToDisplayFor(key: string): Promise<number | undefined | null>;
79
79
  setActiveSpanId(spanId: string): void;
80
+ encodeToBase64(data: Uint8Array): Promise<string | null>;
80
81
  }
81
82
  /**
82
83
  * Our internal interface for calling native functions