@sentry/react-native 6.13.1 → 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.
- 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/client.d.ts +12 -0
- package/dist/js/client.d.ts.map +1 -1
- package/dist/js/client.js +19 -0
- package/dist/js/client.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 +12 -1
- package/dist/js/feedback/FeedbackWidget.d.ts.map +1 -1
- package/dist/js/feedback/FeedbackWidget.js +78 -13
- 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/expocontext.d.ts +18 -0
- package/dist/js/integrations/expocontext.d.ts.map +1 -1
- package/dist/js/integrations/expocontext.js +20 -12
- package/dist/js/integrations/expocontext.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/replay/mobilereplay.d.ts +14 -1
- package/dist/js/replay/mobilereplay.d.ts.map +1 -1
- package/dist/js/replay/mobilereplay.js +9 -1
- package/dist/js/replay/mobilereplay.js.map +1 -1
- package/dist/js/sdk.js +1 -1
- package/dist/js/sdk.js.map +1 -1
- package/dist/js/tracing/reactnativetracing.d.ts +4 -1
- package/dist/js/tracing/reactnativetracing.d.ts.map +1 -1
- package/dist/js/tracing/reactnativetracing.js +5 -1
- package/dist/js/tracing/reactnativetracing.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/RNSentryReplay.mm +1 -2
- package/ios/RNSentryVersion.m +1 -1
- package/package.json +6 -6
- package/src/js/NativeRNSentry.ts +1 -0
- package/ts3.8/dist/js/NativeRNSentry.d.ts +1 -0
- package/ts3.8/dist/js/client.d.ts +12 -0
- package/ts3.8/dist/js/feedback/FeedbackButton.d.ts +23 -0
- package/ts3.8/dist/js/feedback/FeedbackWidget.d.ts +12 -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/integrations/expocontext.d.ts +18 -0
- package/ts3.8/dist/js/replay/mobilereplay.d.ts +14 -1
- package/ts3.8/dist/js/tracing/reactnativetracing.d.ts +4 -1
- 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
package/ios/RNSentryReplay.mm
CHANGED
|
@@ -27,8 +27,7 @@
|
|
|
27
27
|
@"errorSampleRate" : options[@"replaysOnErrorSampleRate"] ?: [NSNull null],
|
|
28
28
|
@"maskAllImages" : replayOptions[@"maskAllImages"] ?: [NSNull null],
|
|
29
29
|
@"maskAllText" : replayOptions[@"maskAllText"] ?: [NSNull null],
|
|
30
|
-
@"
|
|
31
|
-
?: [NSNull null],
|
|
30
|
+
@"enableViewRendererV2" : replayOptions[@"enableViewRendererV2"] ?: [NSNull null],
|
|
32
31
|
@"enableFastViewRendering" : replayOptions[@"enableFastViewRendering"] ?: [NSNull null],
|
|
33
32
|
@"maskedViewClasses" : [RNSentryReplay getReplayRNRedactClasses:replayOptions],
|
|
34
33
|
@"sdkInfo" :
|
package/ios/RNSentryVersion.m
CHANGED
|
@@ -3,4 +3,4 @@
|
|
|
3
3
|
NSString *const NATIVE_SDK_NAME = @"sentry.cocoa.react-native";
|
|
4
4
|
NSString *const REACT_NATIVE_SDK_NAME = @"sentry.javascript.react-native";
|
|
5
5
|
NSString *const REACT_NATIVE_SDK_PACKAGE_NAME = @"npm:@sentry/react-native";
|
|
6
|
-
NSString *const REACT_NATIVE_SDK_PACKAGE_VERSION = @"6.
|
|
6
|
+
NSString *const REACT_NATIVE_SDK_PACKAGE_VERSION = @"6.15.0";
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@sentry/react-native",
|
|
3
3
|
"homepage": "https://github.com/getsentry/sentry-react-native",
|
|
4
4
|
"repository": "https://github.com/getsentry/sentry-react-native",
|
|
5
|
-
"version": "6.
|
|
5
|
+
"version": "6.15.0",
|
|
6
6
|
"description": "Official Sentry SDK for react-native",
|
|
7
7
|
"typings": "dist/js/index.d.ts",
|
|
8
8
|
"types": "dist/js/index.d.ts",
|
|
@@ -65,9 +65,9 @@
|
|
|
65
65
|
"react-native": ">=0.65.0"
|
|
66
66
|
},
|
|
67
67
|
"dependencies": {
|
|
68
|
-
"@sentry/babel-plugin-component-annotate": "3.
|
|
68
|
+
"@sentry/babel-plugin-component-annotate": "3.5.0",
|
|
69
69
|
"@sentry/browser": "8.54.0",
|
|
70
|
-
"@sentry/cli": "2.
|
|
70
|
+
"@sentry/cli": "2.46.0",
|
|
71
71
|
"@sentry/core": "8.54.0",
|
|
72
72
|
"@sentry/react": "8.54.0",
|
|
73
73
|
"@sentry/types": "8.54.0",
|
|
@@ -75,13 +75,13 @@
|
|
|
75
75
|
},
|
|
76
76
|
"devDependencies": {
|
|
77
77
|
"@babel/core": "^7.25.2",
|
|
78
|
-
"@expo/metro-config": "0.
|
|
78
|
+
"@expo/metro-config": "~0.20.0",
|
|
79
79
|
"@mswjs/interceptors": "^0.25.15",
|
|
80
80
|
"@react-native/babel-preset": "0.77.1",
|
|
81
81
|
"@sentry-internal/eslint-config-sdk": "8.54.0",
|
|
82
82
|
"@sentry-internal/eslint-plugin-sdk": "8.54.0",
|
|
83
83
|
"@sentry-internal/typescript": "8.54.0",
|
|
84
|
-
"@sentry/wizard": "
|
|
84
|
+
"@sentry/wizard": "5.1.0",
|
|
85
85
|
"@testing-library/react-native": "^12.7.2",
|
|
86
86
|
"@types/jest": "^29.5.13",
|
|
87
87
|
"@types/node": "^20.9.3",
|
|
@@ -98,7 +98,7 @@
|
|
|
98
98
|
"eslint": "^7.6.0",
|
|
99
99
|
"eslint-plugin-react": "^7.20.6",
|
|
100
100
|
"eslint-plugin-react-native": "^3.8.1",
|
|
101
|
-
"expo": "^
|
|
101
|
+
"expo": "^53.0.0",
|
|
102
102
|
"expo-module-scripts": "3.1.0",
|
|
103
103
|
"jest": "^29.6.2",
|
|
104
104
|
"jest-environment-jsdom": "^29.6.2",
|
package/src/js/NativeRNSentry.ts
CHANGED
|
@@ -51,6 +51,7 @@ export interface Spec extends TurboModule {
|
|
|
51
51
|
getDataFromUri(uri: string): Promise<number[]>;
|
|
52
52
|
popTimeToDisplayFor(key: string): Promise<number | undefined | null>;
|
|
53
53
|
setActiveSpanId(spanId: string): boolean;
|
|
54
|
+
encodeToBase64(data: number[]): Promise<string | undefined | null>;
|
|
54
55
|
}
|
|
55
56
|
|
|
56
57
|
export type NativeStackFrame = {
|
|
@@ -46,6 +46,7 @@ export interface Spec extends TurboModule {
|
|
|
46
46
|
getDataFromUri(uri: string): Promise<number[]>;
|
|
47
47
|
popTimeToDisplayFor(key: string): Promise<number | undefined | null>;
|
|
48
48
|
setActiveSpanId(spanId: string): boolean;
|
|
49
|
+
encodeToBase64(data: number[]): Promise<string | undefined | null>;
|
|
49
50
|
}
|
|
50
51
|
export type NativeStackFrame = {
|
|
51
52
|
platform: string;
|
|
@@ -44,6 +44,18 @@ export declare class ReactNativeClient extends BaseClient<ReactNativeClientOptio
|
|
|
44
44
|
* @inheritDoc
|
|
45
45
|
*/
|
|
46
46
|
init(): void;
|
|
47
|
+
/**
|
|
48
|
+
* Register a hook on this client.
|
|
49
|
+
*
|
|
50
|
+
* (Generic method signature to allow for custom React Native Client events.)
|
|
51
|
+
*/
|
|
52
|
+
on(hook: string, callback: unknown): () => void;
|
|
53
|
+
/**
|
|
54
|
+
* Emit a hook that was previously registered via `on()`.
|
|
55
|
+
*
|
|
56
|
+
* (Generic method signature to allow for custom React Native Client events.)
|
|
57
|
+
*/
|
|
58
|
+
emit(hook: string, ...rest: unknown[]): void;
|
|
47
59
|
/**
|
|
48
60
|
* Starts native client with dsn and options
|
|
49
61
|
*/
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import type { FeedbackButtonProps } from './FeedbackWidget.types';
|
|
3
|
+
/**
|
|
4
|
+
* @beta
|
|
5
|
+
* Implements a feedback button that opens the FeedbackForm.
|
|
6
|
+
*/
|
|
7
|
+
export declare class FeedbackButton extends React.Component<FeedbackButtonProps> {
|
|
8
|
+
private _themeListener;
|
|
9
|
+
constructor(props: FeedbackButtonProps);
|
|
10
|
+
/**
|
|
11
|
+
* Adds a listener for theme changes.
|
|
12
|
+
*/
|
|
13
|
+
componentDidMount(): void;
|
|
14
|
+
/**
|
|
15
|
+
* Removes the theme listener.
|
|
16
|
+
*/
|
|
17
|
+
componentWillUnmount(): void;
|
|
18
|
+
/**
|
|
19
|
+
* Renders the feedback button.
|
|
20
|
+
*/
|
|
21
|
+
render(): React.ReactNode;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=FeedbackButton.d.ts.map
|
|
@@ -7,19 +7,30 @@ import type { FeedbackWidgetProps, FeedbackWidgetState } from './FeedbackWidget.
|
|
|
7
7
|
export declare class FeedbackWidget extends React.Component<FeedbackWidgetProps, FeedbackWidgetState> {
|
|
8
8
|
static defaultProps: Partial<FeedbackWidgetProps>;
|
|
9
9
|
private static _savedState;
|
|
10
|
+
private _themeListener;
|
|
10
11
|
private _didSubmitForm;
|
|
11
12
|
constructor(props: FeedbackWidgetProps);
|
|
13
|
+
/**
|
|
14
|
+
* For testing purposes only.
|
|
15
|
+
*/
|
|
16
|
+
static reset(): void;
|
|
12
17
|
handleFeedbackSubmit: () => void;
|
|
13
18
|
onScreenshotButtonPress: () => void;
|
|
14
19
|
/**
|
|
15
|
-
*
|
|
20
|
+
* Add a listener to the theme change event.
|
|
21
|
+
*/
|
|
22
|
+
componentDidMount(): void;
|
|
23
|
+
/**
|
|
24
|
+
* Save the state before unmounting the component and remove the theme listener.
|
|
16
25
|
*/
|
|
17
26
|
componentWillUnmount(): void;
|
|
18
27
|
/**
|
|
19
28
|
* Renders the feedback form screen.
|
|
20
29
|
*/
|
|
21
30
|
render(): React.ReactNode;
|
|
31
|
+
private _setCapturedScreenshot;
|
|
22
32
|
private _saveFormState;
|
|
23
33
|
private _clearFormState;
|
|
34
|
+
private _hasScreenshot;
|
|
24
35
|
}
|
|
25
36
|
//# sourceMappingURL=FeedbackWidget.d.ts.map
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import type { ViewStyle } from 'react-native';
|
|
2
|
-
import type {
|
|
3
|
-
|
|
2
|
+
import type { FeedbackWidgetTheme } from './FeedbackWidget.theme';
|
|
3
|
+
import type { FeedbackButtonStyles, FeedbackWidgetStyles } from './FeedbackWidget.types';
|
|
4
|
+
declare const defaultStyles: (theme: FeedbackWidgetTheme) => FeedbackWidgetStyles;
|
|
5
|
+
export declare const defaultButtonStyles: (theme: FeedbackWidgetTheme) => FeedbackButtonStyles;
|
|
6
|
+
export declare const defaultScreenshotButtonStyles: (theme: FeedbackWidgetTheme) => FeedbackButtonStyles;
|
|
4
7
|
export declare const modalWrapper: ViewStyle;
|
|
5
|
-
export declare const modalSheetContainer: ViewStyle;
|
|
8
|
+
export declare const modalSheetContainer: (theme: FeedbackWidgetTheme) => ViewStyle;
|
|
6
9
|
export declare const topSpacer: ViewStyle;
|
|
7
10
|
export default defaultStyles;
|
|
8
11
|
//# sourceMappingURL=FeedbackWidget.styles.d.ts.map
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Get the theme for the feedback widget based on the current color scheme
|
|
3
|
+
*/
|
|
4
|
+
export declare function getTheme(): FeedbackWidgetTheme;
|
|
5
|
+
export interface FeedbackWidgetTheme {
|
|
6
|
+
/**
|
|
7
|
+
* Background color for surfaces
|
|
8
|
+
*/
|
|
9
|
+
background: string;
|
|
10
|
+
/**
|
|
11
|
+
* Foreground color (i.e. text color)
|
|
12
|
+
*/
|
|
13
|
+
foreground: string;
|
|
14
|
+
/**
|
|
15
|
+
* Foreground color for accented elements
|
|
16
|
+
*/
|
|
17
|
+
accentForeground?: string;
|
|
18
|
+
/**
|
|
19
|
+
* Background color for accented elements
|
|
20
|
+
*/
|
|
21
|
+
accentBackground?: string;
|
|
22
|
+
/**
|
|
23
|
+
* Border color
|
|
24
|
+
*/
|
|
25
|
+
border?: string;
|
|
26
|
+
/**
|
|
27
|
+
* Color for feedback icon
|
|
28
|
+
*/
|
|
29
|
+
feedbackIcon?: string;
|
|
30
|
+
/**
|
|
31
|
+
* Color for Sentry logo
|
|
32
|
+
*/
|
|
33
|
+
sentryLogo?: string;
|
|
34
|
+
}
|
|
35
|
+
export declare const LightTheme: FeedbackWidgetTheme;
|
|
36
|
+
export declare const DarkTheme: FeedbackWidgetTheme;
|
|
37
|
+
//# sourceMappingURL=FeedbackWidget.theme.d.ts.map
|
|
@@ -41,6 +41,11 @@ export interface FeedbackGeneralConfiguration {
|
|
|
41
41
|
* @default false
|
|
42
42
|
*/
|
|
43
43
|
enableScreenshot?: boolean;
|
|
44
|
+
/**
|
|
45
|
+
* This flag determines whether the "Take Screenshot" button is displayed
|
|
46
|
+
* @default false
|
|
47
|
+
*/
|
|
48
|
+
enableTakeScreenshot?: boolean;
|
|
44
49
|
/**
|
|
45
50
|
* Fill in email/name input fields with Sentry user context if it exists.
|
|
46
51
|
* The value of the email/name keys represent the properties of your user context.
|
|
@@ -99,13 +104,17 @@ export interface FeedbackTextConfiguration {
|
|
|
99
104
|
*/
|
|
100
105
|
isRequiredLabel?: string;
|
|
101
106
|
/**
|
|
102
|
-
* The label for the button that adds a screenshot
|
|
107
|
+
* The label for the button that adds a screenshot
|
|
103
108
|
*/
|
|
104
109
|
addScreenshotButtonLabel?: string;
|
|
105
110
|
/**
|
|
106
|
-
* The label for the button that removes a screenshot
|
|
111
|
+
* The label for the button that removes a screenshot
|
|
107
112
|
*/
|
|
108
113
|
removeScreenshotButtonLabel?: string;
|
|
114
|
+
/**
|
|
115
|
+
* The label for the button that shows the capture screenshot button
|
|
116
|
+
*/
|
|
117
|
+
captureScreenshotButtonLabel?: string;
|
|
109
118
|
/**
|
|
110
119
|
* The title of the error dialog
|
|
111
120
|
*/
|
|
@@ -118,11 +127,41 @@ export interface FeedbackTextConfiguration {
|
|
|
118
127
|
* The error message when the email is invalid
|
|
119
128
|
*/
|
|
120
129
|
emailError?: string;
|
|
130
|
+
/**
|
|
131
|
+
* The error message when the capture screenshot fails
|
|
132
|
+
*/
|
|
133
|
+
captureScreenshotError?: string;
|
|
121
134
|
/**
|
|
122
135
|
* Message when there is a generic error
|
|
123
136
|
*/
|
|
124
137
|
genericError?: string;
|
|
125
138
|
}
|
|
139
|
+
/**
|
|
140
|
+
* The FeedbackButton text labels that can be customized
|
|
141
|
+
*/
|
|
142
|
+
export interface FeedbackButtonTextConfiguration {
|
|
143
|
+
/**
|
|
144
|
+
* The label for the Feedback widget button that opens the dialog
|
|
145
|
+
*/
|
|
146
|
+
triggerLabel?: string;
|
|
147
|
+
/**
|
|
148
|
+
* The aria label for the Feedback widget button that opens the dialog
|
|
149
|
+
*/
|
|
150
|
+
triggerAriaLabel?: string;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* The ScreenshotButton text labels that can be customized
|
|
154
|
+
*/
|
|
155
|
+
export interface ScreenshotButtonTextConfiguration {
|
|
156
|
+
/**
|
|
157
|
+
* The label for the Screenshot button
|
|
158
|
+
*/
|
|
159
|
+
triggerLabel?: string;
|
|
160
|
+
/**
|
|
161
|
+
* The aria label for the Screenshot button
|
|
162
|
+
*/
|
|
163
|
+
triggerAriaLabel?: string;
|
|
164
|
+
}
|
|
126
165
|
/**
|
|
127
166
|
* The public callbacks available for the feedback integration
|
|
128
167
|
*/
|
|
@@ -199,9 +238,39 @@ export interface FeedbackWidgetStyles {
|
|
|
199
238
|
screenshotContainer?: ViewStyle;
|
|
200
239
|
screenshotThumbnail?: ImageStyle;
|
|
201
240
|
screenshotText?: TextStyle;
|
|
241
|
+
takeScreenshotButton?: ViewStyle;
|
|
242
|
+
takeScreenshotText?: TextStyle;
|
|
202
243
|
titleContainer?: ViewStyle;
|
|
203
244
|
sentryLogo?: ImageStyle;
|
|
204
245
|
}
|
|
246
|
+
/**
|
|
247
|
+
* The props for the feedback button
|
|
248
|
+
*/
|
|
249
|
+
export interface FeedbackButtonProps extends FeedbackButtonTextConfiguration {
|
|
250
|
+
styles?: FeedbackButtonStyles;
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* The styles for the feedback button
|
|
254
|
+
*/
|
|
255
|
+
export interface FeedbackButtonStyles {
|
|
256
|
+
triggerButton?: ViewStyle;
|
|
257
|
+
triggerText?: TextStyle;
|
|
258
|
+
triggerIcon?: ImageStyle;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* The props for the screenshot button
|
|
262
|
+
*/
|
|
263
|
+
export interface ScreenshotButtonProps extends ScreenshotButtonTextConfiguration {
|
|
264
|
+
styles?: ScreenshotButtonStyles;
|
|
265
|
+
}
|
|
266
|
+
/**
|
|
267
|
+
* The styles for the screenshot button
|
|
268
|
+
*/
|
|
269
|
+
export interface ScreenshotButtonStyles {
|
|
270
|
+
triggerButton?: ViewStyle;
|
|
271
|
+
triggerText?: TextStyle;
|
|
272
|
+
triggerIcon?: ImageStyle;
|
|
273
|
+
}
|
|
205
274
|
/**
|
|
206
275
|
* The state of the feedback form
|
|
207
276
|
*/
|
|
@@ -1,33 +1,53 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
export declare const PULL_DOWN_CLOSE_THRESHOLD = 200;
|
|
2
|
+
export declare const SLIDE_ANIMATION_DURATION = 200;
|
|
3
|
+
export declare const BACKGROUND_ANIMATION_DURATION = 200;
|
|
4
|
+
declare abstract class FeedbackManager {
|
|
5
|
+
protected static _isVisible: boolean;
|
|
6
|
+
protected static _setVisibility: (visible: boolean) => void;
|
|
7
|
+
protected static get _feedbackComponentName(): string;
|
|
8
|
+
static initialize(setVisibility: (visible: boolean) => void): void;
|
|
9
|
+
/**
|
|
10
|
+
* For testing purposes only.
|
|
11
|
+
*/
|
|
12
|
+
static reset(): void;
|
|
13
|
+
static show(): void;
|
|
14
|
+
static hide(): void;
|
|
15
|
+
static isFormVisible(): boolean;
|
|
7
16
|
}
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
17
|
+
/**
|
|
18
|
+
* Provides functionality to show and hide the feedback widget.
|
|
19
|
+
*/
|
|
20
|
+
export declare class FeedbackWidgetManager extends FeedbackManager {
|
|
21
|
+
/**
|
|
22
|
+
* Returns the name of the feedback component.
|
|
23
|
+
*/
|
|
24
|
+
protected static get _feedbackComponentName(): string;
|
|
13
25
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
26
|
+
/**
|
|
27
|
+
* Provides functionality to show and hide the feedback button.
|
|
28
|
+
*/
|
|
29
|
+
export declare class FeedbackButtonManager extends FeedbackManager {
|
|
18
30
|
/**
|
|
19
|
-
*
|
|
31
|
+
* Returns the name of the feedback component.
|
|
20
32
|
*/
|
|
21
|
-
|
|
33
|
+
protected static get _feedbackComponentName(): string;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Provides functionality to show and hide the screenshot button.
|
|
37
|
+
*/
|
|
38
|
+
export declare class ScreenshotButtonManager extends FeedbackManager {
|
|
22
39
|
/**
|
|
23
|
-
*
|
|
40
|
+
* Returns the name of the feedback component.
|
|
24
41
|
*/
|
|
25
|
-
|
|
26
|
-
private _handleScroll;
|
|
27
|
-
private _setVisibilityFunction;
|
|
28
|
-
private _handleClose;
|
|
42
|
+
protected static get _feedbackComponentName(): string;
|
|
29
43
|
}
|
|
30
44
|
declare const showFeedbackWidget: () => void;
|
|
31
45
|
declare const resetFeedbackWidgetManager: () => void;
|
|
32
|
-
|
|
46
|
+
declare const showFeedbackButton: () => void;
|
|
47
|
+
declare const hideFeedbackButton: () => void;
|
|
48
|
+
declare const resetFeedbackButtonManager: () => void;
|
|
49
|
+
declare const showScreenshotButton: () => void;
|
|
50
|
+
declare const hideScreenshotButton: () => void;
|
|
51
|
+
declare const resetScreenshotButtonManager: () => void;
|
|
52
|
+
export { showFeedbackButton, hideFeedbackButton, showFeedbackWidget, showScreenshotButton, hideScreenshotButton, resetFeedbackButtonManager, resetFeedbackWidgetManager, resetScreenshotButtonManager };
|
|
33
53
|
//# sourceMappingURL=FeedbackWidgetManager.d.ts.map
|
|
@@ -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,4 +2,22 @@ import type { Integration } from '@sentry/core';
|
|
|
2
2
|
export declare const OTA_UPDATES_CONTEXT_KEY = "ota_updates";
|
|
3
3
|
/** Load device context from expo modules. */
|
|
4
4
|
export declare const expoContextIntegration: () => Integration;
|
|
5
|
+
/**
|
|
6
|
+
* @internal Exposed for testing purposes
|
|
7
|
+
*/
|
|
8
|
+
export declare function getExpoUpdatesContext(): ExpoUpdatesContext;
|
|
9
|
+
type ExpoUpdatesContext = Partial<{
|
|
10
|
+
is_enabled: boolean;
|
|
11
|
+
is_embedded_launch: boolean;
|
|
12
|
+
is_emergency_launch: boolean;
|
|
13
|
+
is_using_embedded_assets: boolean;
|
|
14
|
+
update_id: string;
|
|
15
|
+
channel: string;
|
|
16
|
+
runtime_version: string;
|
|
17
|
+
check_automatically: string;
|
|
18
|
+
emergency_launch_reason: string;
|
|
19
|
+
launch_duration: number;
|
|
20
|
+
created_at: string;
|
|
21
|
+
}>;
|
|
22
|
+
export {};
|
|
5
23
|
//# sourceMappingURL=expocontext.d.ts.map
|