/* eslint-disable array-callback-return */ import variables from 'config/variables'; import { PureComponent } from 'react'; import { MdShowChart, MdRestartAlt, MdDownload } from 'react-icons/md'; import { FaTrophy } from 'react-icons/fa'; import { toast } from 'react-toastify'; import { Button } from 'components/Elements'; import { Header, CustomActions } from 'components/Layout/Settings'; import { saveFile } from 'utils/saveFile'; import { getLocalisedAchievementData, achievements, checkAchievements } from 'utils/achievements'; class Stats extends PureComponent { constructor() { super(); this.state = { stats: JSON.parse(localStorage.getItem('statsData')) || {}, achievements, }; } updateAchievements() { const achieved = checkAchievements(this.state.stats); this.setState({ achievements: achieved, }); } getUnlockedCount() { let count = 0; this.state.achievements.forEach((achievement) => { if (achievement.achieved) { count++; } }); return count; } resetStats() { localStorage.setItem('statsData', JSON.stringify({})); localStorage.setItem('achievements', JSON.stringify(achievements)); this.setState({ stats: {}, achievements, }); toast(variables.getMessage('toasts.stats_reset')); this.updateAchievements(); this.forceUpdate(); } downloadStats() { let date = new Date(); // Format the date as YYYY-MM-DD_HH-MM-SS let formattedDate = `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')}_${date.getHours().toString().padStart(2, '0')}-${date.getMinutes().toString().padStart(2, '0')}-${date.getSeconds().toString().padStart(2, '0')}`; let filename = `mue_stats_${formattedDate}.json`; saveFile(JSON.stringify(this.state.stats, null, 2), filename); } componentDidMount() { this.updateAchievements(); this.forceUpdate(); } render() { const achievementElement = (key, id, achieved) => { const { name, description } = getLocalisedAchievementData(id); return (
{name} {achieved ? description : '?????'}
); }; const STATS_SECTION = 'modals.main.settings.sections.stats'; return ( <>
{variables.getMessage(`${STATS_SECTION}.sections.tabs_opened`)}{' '} {this.state.stats['tabs-opened'] || 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.backgrounds_favourited', )}{' '} {this.state.stats.feature ? this.state.stats.feature['background-favourite'] || 0 : 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.backgrounds_downloaded', )}{' '} {this.state.stats.feature ? this.state.stats.feature['background-download'] || 0 : 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.quotes_favourited', )}{' '} {this.state.stats.feature ? this.state.stats.feature['quoted-favourite'] || 0 : 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.quicklinks_added', )}{' '} {this.state.stats.feature ? this.state.stats.feature['quicklink-add'] || 0 : 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.settings_changed', )}{' '} {this.state.stats.setting ? Object.keys(this.state.stats.setting).length : 0}
{variables.getMessage( 'modals.main.settings.sections.stats.sections.addons_installed', )}{' '} {this.state.stats.marketplace ? this.state.stats.marketplace['install'] : 0}
{variables.getMessage(`${STATS_SECTION}.achievements`)}
{variables.getMessage(`${STATS_SECTION}.unlocked`, { count: this.getUnlockedCount() + '/' + this.state.achievements.length, })}
{this.state.achievements.map((achievement, index) => { if (achievement.achieved) { return achievementElement(index, achievement.id, achievement.achieved); } })}
{variables.getMessage(`${STATS_SECTION}.locked`)}
{this.state.achievements.map((achievement, index) => { if (!achievement.achieved) { return achievementElement(index, achievement.id, achievement.achieved); } })}
); } } export { Stats as default, Stats };