2023-04-26 15:17:23 +00:00
|
|
|
import { useLocalStorage } from '@vegaprotocol/react-helpers';
|
2023-09-01 09:00:20 +00:00
|
|
|
import { useCallback, useEffect, useState } from 'react';
|
2023-06-06 13:10:03 +00:00
|
|
|
import { SentryInit, SentryClose } from '@vegaprotocol/logger';
|
2023-09-01 09:00:20 +00:00
|
|
|
import { Networks, useEnvironment } from '@vegaprotocol/environment';
|
|
|
|
|
2023-04-26 15:17:23 +00:00
|
|
|
export const STORAGE_KEY = 'vega_telemetry_approval';
|
2023-09-01 09:00:20 +00:00
|
|
|
export const STORAGE_SECOND_KEY = 'vega_telemetry_viewed';
|
2023-04-26 15:17:23 +00:00
|
|
|
|
|
|
|
export const useTelemetryApproval = (): [
|
2023-09-01 09:00:20 +00:00
|
|
|
value: string,
|
|
|
|
setValue: (value: string) => void,
|
|
|
|
shouldOpen: boolean,
|
|
|
|
close: () => void
|
2023-04-26 15:17:23 +00:00
|
|
|
] => {
|
2023-06-27 06:40:42 +00:00
|
|
|
const { VEGA_ENV, SENTRY_DSN } = useEnvironment();
|
2023-09-01 09:00:20 +00:00
|
|
|
const defaultTelemetryValue =
|
|
|
|
VEGA_ENV === Networks.MAINNET ? 'false' : 'true';
|
|
|
|
const [value, setValue] = useLocalStorage(STORAGE_KEY);
|
|
|
|
const [viewedValue, setViewedValue] = useLocalStorage(STORAGE_SECOND_KEY);
|
|
|
|
const [shouldOpen, setShouldOpen] = useState(!value || !viewedValue);
|
|
|
|
const close = useCallback(() => {
|
|
|
|
setShouldOpen(false);
|
|
|
|
setViewedValue('true');
|
|
|
|
}, [setViewedValue]);
|
|
|
|
const manageValue = useCallback(
|
|
|
|
(value: string) => {
|
|
|
|
if (value === 'true' && SENTRY_DSN) {
|
2023-06-27 06:40:42 +00:00
|
|
|
SentryInit(SENTRY_DSN, VEGA_ENV);
|
2023-09-01 09:00:20 +00:00
|
|
|
return setValue('true');
|
2023-04-26 15:17:23 +00:00
|
|
|
}
|
|
|
|
SentryClose();
|
2023-09-01 09:00:20 +00:00
|
|
|
setValue('false');
|
|
|
|
},
|
|
|
|
[setValue, SENTRY_DSN, VEGA_ENV]
|
|
|
|
);
|
|
|
|
const setTelemetryValue = useCallback(
|
|
|
|
(value: string) => {
|
|
|
|
setShouldOpen(false);
|
|
|
|
setViewedValue('true');
|
|
|
|
manageValue(value);
|
2023-04-26 15:17:23 +00:00
|
|
|
},
|
2023-09-01 09:00:20 +00:00
|
|
|
[manageValue, setViewedValue]
|
2023-04-26 15:17:23 +00:00
|
|
|
);
|
2023-09-01 09:00:20 +00:00
|
|
|
useEffect(() => {
|
|
|
|
if (!value) {
|
|
|
|
manageValue(defaultTelemetryValue);
|
|
|
|
}
|
|
|
|
}, [value, manageValue, defaultTelemetryValue]);
|
|
|
|
|
|
|
|
return [value || '', setTelemetryValue, shouldOpen, close];
|
2023-04-26 15:17:23 +00:00
|
|
|
};
|