From 84903c1e5182124b1bb618b7d8754cb70d0a6647 Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Wed, 23 Feb 2022 18:11:37 +0100 Subject: feat: improve Ackee tracking (#11) * build(deps): add use-ackee hook package * chore: create a context provider for Ackee The provider allows users to change the 'detailed' settings. * chore: add a select menu to choose which info to share with Ackee * chore: add a tooltip for askee settings * chore: replace default select styles with custom styles * chore: register user choice in localstorage * chore: replace Matomo with Ackee in legal notice --- .../Settings/AckeeSelect/AckeeSelect.tsx | 83 ++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 src/components/Settings/AckeeSelect/AckeeSelect.tsx (limited to 'src/components/Settings/AckeeSelect/AckeeSelect.tsx') diff --git a/src/components/Settings/AckeeSelect/AckeeSelect.tsx b/src/components/Settings/AckeeSelect/AckeeSelect.tsx new file mode 100644 index 0000000..58fc994 --- /dev/null +++ b/src/components/Settings/AckeeSelect/AckeeSelect.tsx @@ -0,0 +1,83 @@ +import { Label, Select } from '@components/Form'; +import Tooltip from '@components/Tooltip/Tooltip'; +import { LocalStorage } from '@services/local-storage'; +import { useAckeeTracker } from '@utils/providers/ackee'; +import { useEffect, useState } from 'react'; +import { useIntl } from 'react-intl'; +import styles from './AckeeSelect.module.scss'; + +const AckeeSelect = () => { + const intl = useIntl(); + const options = [ + { + id: 'partial', + name: intl.formatMessage({ + defaultMessage: 'Partial', + description: 'AckeeSelect: partial option name', + }), + value: 'partial', + }, + { + id: 'full', + name: intl.formatMessage({ + defaultMessage: 'Full', + description: 'AckeeSelect: full option name', + }), + value: 'full', + }, + ]; + const [value, setValue] = useState('full'); + const { setDetailed } = useAckeeTracker(); + + useEffect(() => { + setDetailed(value === 'full'); + }, [setDetailed, value]); + + useEffect(() => { + const initialState = LocalStorage.get('ackee-tracking'); + if (initialState) setValue(initialState); + }, []); + + useEffect(() => { + LocalStorage.set('ackee-tracking', `${value}`); + }, [value]); + + const label = ( +