Update sentry reporting

This commit is contained in:
Zhiyuan Zheng 2022-01-08 11:19:24 +01:00
parent e3c84f6146
commit e92a7907e6
3 changed files with 42 additions and 15 deletions

View File

@ -58,9 +58,9 @@ const apiGeneral = async <T = unknown>({
}) })
}) })
.catch(error => { .catch(error => {
if (sentry && Math.random() < 0.001) { if (sentry && Math.random() < 0.01) {
Sentry.Native.setExtras({ Sentry.Native.setExtras({
API: 'instance', API: 'general',
...(error.response && { response: error.response }), ...(error.response && { response: error.response }),
...(error.request && { request: error.request }) ...(error.request && { request: error.request })
}) })

View File

@ -61,7 +61,7 @@ const apiTooot = async <T = unknown>({
}) })
}) })
.catch(error => { .catch(error => {
if (sentry && Math.random() < 0.005) { if (sentry && Math.random() < 0.01) {
Sentry.Native.setExtras({ Sentry.Native.setExtras({
API: 'tooot', API: 'tooot',
...(error.response && { response: error.response }), ...(error.response && { response: error.response }),

View File

@ -7,6 +7,7 @@ import { findIndex } from 'lodash'
import React, { useCallback, useEffect, useRef, useState } from 'react' import React, { useCallback, useEffect, useRef, useState } from 'react'
import { FlatList } from 'react-native' import { FlatList } from 'react-native'
import { InfiniteQueryObserver, useQueryClient } from 'react-query' import { InfiniteQueryObserver, useQueryClient } from 'react-query'
import * as Sentry from 'sentry-expo'
const TabSharedToot: React.FC<TabSharedStackScreenProps<'Tab-Shared-Toot'>> = ({ const TabSharedToot: React.FC<TabSharedStackScreenProps<'Tab-Shared-Toot'>> = ({
route: { route: {
@ -40,30 +41,56 @@ const TabSharedToot: React.FC<TabSharedStackScreenProps<'Tab-Shared-Toot'>> = ({
if (!scrolled.current) { if (!scrolled.current) {
scrolled.current = true scrolled.current = true
const pointer = findIndex(flattenData, ['id', toot.id]) const pointer = findIndex(flattenData, ['id', toot.id])
pointer < flattenData.length && try {
setTimeout(() => { pointer < flattenData.length &&
flRef.current?.scrollToIndex({ setTimeout(() => {
flRef.current?.scrollToIndex({
index: pointer,
viewOffset: 100
})
}, 500)
} catch (err) {
if (Math.random() < 0.1) {
Sentry.Native.setExtras({
type: 'original',
index: pointer, index: pointer,
viewOffset: 100 itemsLength: flattenData.length,
flattenData
}) })
}, 500) Sentry.Native.captureException(err)
}
}
} }
} }
}) })
return () => unsubscribe() return () => unsubscribe()
}, []) }, [scrolled.current])
// Toot page auto scroll to selected toot // Toot page auto scroll to selected toot
const onScrollToIndexFailed = useCallback( const onScrollToIndexFailed = useCallback(
error => { error => {
const offset = error.averageItemLength * error.index const offset = error.averageItemLength * error.index
flRef.current?.scrollToOffset({ offset }) flRef.current?.scrollToOffset({ offset })
setTimeout( try {
() => error.index < itemsLength &&
error.index < itemsLength && setTimeout(
flRef.current?.scrollToIndex({ index: error.index, viewOffset: 100 }), () =>
500 flRef.current?.scrollToIndex({
) index: error.index,
viewOffset: 100
}),
500
)
} catch (err) {
if (Math.random() < 0.1) {
Sentry.Native.setExtras({
type: 'onScrollToIndexFailed',
index: error.index,
itemsLength
})
Sentry.Native.captureException(err)
}
}
}, },
[itemsLength] [itemsLength]
) )