@sentry/react-native 6.14.0 → 6.15.1
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/RNSentry.podspec +1 -1
- package/android/src/main/java/io/sentry/react/RNSentryModuleImpl.java +10 -0
- package/android/src/main/java/io/sentry/react/RNSentryVersion.java +1 -1
- package/android/src/newarch/java/io/sentry/react/RNSentryModule.java +5 -0
- package/android/src/oldarch/java/io/sentry/react/RNSentryModule.java +5 -0
- package/dist/js/NativeRNSentry.d.ts +1 -0
- package/dist/js/NativeRNSentry.d.ts.map +1 -1
- package/dist/js/NativeRNSentry.js.map +1 -1
- package/dist/js/feedback/FeedbackButton.d.ts +23 -0
- package/dist/js/feedback/FeedbackButton.d.ts.map +1 -0
- package/dist/js/feedback/FeedbackButton.js +51 -0
- package/dist/js/feedback/FeedbackButton.js.map +1 -0
- package/dist/js/feedback/FeedbackWidget.d.ts +13 -1
- package/dist/js/feedback/FeedbackWidget.d.ts.map +1 -1
- package/dist/js/feedback/FeedbackWidget.js +89 -16
- package/dist/js/feedback/FeedbackWidget.js.map +1 -1
- package/dist/js/feedback/FeedbackWidget.styles.d.ts +6 -3
- package/dist/js/feedback/FeedbackWidget.styles.d.ts.map +1 -1
- package/dist/js/feedback/FeedbackWidget.styles.js +155 -106
- package/dist/js/feedback/FeedbackWidget.styles.js.map +1 -1
- package/dist/js/feedback/FeedbackWidget.theme.d.ts +37 -0
- package/dist/js/feedback/FeedbackWidget.theme.d.ts.map +1 -0
- package/dist/js/feedback/FeedbackWidget.theme.js +31 -0
- package/dist/js/feedback/FeedbackWidget.theme.js.map +1 -0
- package/dist/js/feedback/FeedbackWidget.types.d.ts +71 -2
- package/dist/js/feedback/FeedbackWidget.types.d.ts.map +1 -1
- package/dist/js/feedback/FeedbackWidget.types.js.map +1 -1
- package/dist/js/feedback/FeedbackWidgetManager.d.ts +43 -23
- package/dist/js/feedback/FeedbackWidgetManager.d.ts.map +1 -1
- package/dist/js/feedback/FeedbackWidgetManager.js +62 -138
- package/dist/js/feedback/FeedbackWidgetManager.js.map +1 -1
- package/dist/js/feedback/FeedbackWidgetProvider.d.ts +48 -0
- package/dist/js/feedback/FeedbackWidgetProvider.d.ts.map +1 -0
- package/dist/js/feedback/FeedbackWidgetProvider.js +177 -0
- package/dist/js/feedback/FeedbackWidgetProvider.js.map +1 -0
- package/dist/js/feedback/ScreenshotButton.d.ts +25 -0
- package/dist/js/feedback/ScreenshotButton.d.ts.map +1 -0
- package/dist/js/feedback/ScreenshotButton.js +80 -0
- package/dist/js/feedback/ScreenshotButton.js.map +1 -0
- package/dist/js/feedback/defaults.d.ts +3 -1
- package/dist/js/feedback/defaults.d.ts.map +1 -1
- package/dist/js/feedback/defaults.js +15 -0
- package/dist/js/feedback/defaults.js.map +1 -1
- package/dist/js/feedback/icons.d.ts +30 -0
- package/dist/js/feedback/icons.d.ts.map +1 -0
- package/dist/js/feedback/icons.js +30 -0
- package/dist/js/feedback/icons.js.map +1 -0
- package/dist/js/feedback/integration.d.ts +19 -2
- package/dist/js/feedback/integration.d.ts.map +1 -1
- package/dist/js/feedback/integration.js +58 -3
- package/dist/js/feedback/integration.js.map +1 -1
- package/dist/js/feedback/lazy.d.ts +10 -0
- package/dist/js/feedback/lazy.d.ts.map +1 -1
- package/dist/js/feedback/lazy.js +24 -0
- package/dist/js/feedback/lazy.js.map +1 -1
- package/dist/js/index.d.ts +3 -2
- package/dist/js/index.d.ts.map +1 -1
- package/dist/js/index.js +2 -1
- package/dist/js/index.js.map +1 -1
- package/dist/js/integrations/reactnativeerrorhandlers.d.ts.map +1 -1
- package/dist/js/integrations/reactnativeerrorhandlers.js +65 -31
- package/dist/js/integrations/reactnativeerrorhandlers.js.map +1 -1
- package/dist/js/sdk.js +1 -1
- package/dist/js/sdk.js.map +1 -1
- package/dist/js/utils/worldwide.d.ts +7 -0
- package/dist/js/utils/worldwide.d.ts.map +1 -1
- package/dist/js/utils/worldwide.js.map +1 -1
- package/dist/js/version.d.ts +1 -1
- package/dist/js/version.js +1 -1
- package/dist/js/version.js.map +1 -1
- package/dist/js/wrapper.d.ts +1 -0
- package/dist/js/wrapper.d.ts.map +1 -1
- package/dist/js/wrapper.js +17 -1
- package/dist/js/wrapper.js.map +1 -1
- package/ios/RNSentry.mm +24 -0
- package/ios/RNSentryOnDrawReporter.m +4 -0
- package/ios/RNSentryVersion.m +1 -1
- package/package.json +4 -4
- package/src/js/NativeRNSentry.ts +1 -0
- package/ts3.8/dist/js/NativeRNSentry.d.ts +1 -0
- package/ts3.8/dist/js/feedback/FeedbackButton.d.ts +23 -0
- package/ts3.8/dist/js/feedback/FeedbackWidget.d.ts +13 -1
- package/ts3.8/dist/js/feedback/FeedbackWidget.styles.d.ts +6 -3
- package/ts3.8/dist/js/feedback/FeedbackWidget.theme.d.ts +37 -0
- package/ts3.8/dist/js/feedback/FeedbackWidget.types.d.ts +71 -2
- package/ts3.8/dist/js/feedback/FeedbackWidgetManager.d.ts +43 -23
- package/ts3.8/dist/js/feedback/FeedbackWidgetProvider.d.ts +48 -0
- package/ts3.8/dist/js/feedback/ScreenshotButton.d.ts +25 -0
- package/ts3.8/dist/js/feedback/defaults.d.ts +3 -1
- package/ts3.8/dist/js/feedback/icons.d.ts +30 -0
- package/ts3.8/dist/js/feedback/integration.d.ts +19 -2
- package/ts3.8/dist/js/feedback/lazy.d.ts +10 -0
- package/ts3.8/dist/js/index.d.ts +3 -2
- package/ts3.8/dist/js/utils/worldwide.d.ts +7 -0
- package/ts3.8/dist/js/version.d.ts +1 -1
- 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 {
|
|
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
|
|
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
|
package/ts3.8/dist/js/index.d.ts
CHANGED
|
@@ -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;
|
|
@@ -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
|