/* eslint-disable array-callback-return */ import variables from 'modules/variables'; import { PureComponent } from 'preact/compat'; import { MdShowChart, MdRestartAlt } from 'react-icons/md'; import { FaTrophy } from 'react-icons/fa'; import { toast } from 'react-toastify'; import achievementsData from 'modules/helpers/settings/achievements.json'; import translations from 'modules/helpers/settings/achievement_translations/index'; const achievementLanguage = { de_DE: translations.de_DE, en_GB: translations.en_GB, en_US: translations.en_US, es: translations.es, fr: translations.fr, nl: translations.nl, no: translations.no, ru: translations.ru, zh_CN: translations.zh_CN, id_ID: translations.id_ID, tr_TR: translations.tr_TR, }; export default class Stats extends PureComponent { constructor() { super(); this.state = { stats: JSON.parse(localStorage.getItem('statsData')) || {}, achievements: achievementsData.achievements, }; } getAchievements() { const achievements = this.state.achievements; achievements.forEach((achievement) => { switch (achievement.condition.type) { case 'tabsOpened': if (this.state.stats['tabs-opened'] >= achievement.condition.amount) { achievement.achieved = true; } break; case 'addonInstall': if (this.state.stats.marketplace) { if (this.state.stats.marketplace['install'] >= achievement.condition.amount) { achievement.achieved = true; } } break; default: break; } }); this.setState({ achievements, }); } getUnlockedCount() { let count = 0; this.state.achievements.forEach((achievement) => { if (achievement.achieved) { count++; } }); return count; } resetStats() { localStorage.setItem('statsData', JSON.stringify({})); this.setState({ stats: {}, }); toast.success('Stats reset'); this.getAchievements(); this.forceUpdate(); } componentDidMount() { this.getAchievements(); this.forceUpdate(); } render() { const achievementElement = (key, name, achieved) => (