+++ /dev/null
-import PropTypes from 'prop-types';
-import React from 'react';
-
-import { CONFIG, DUNGEONS, makeEmptyState } from '../helpers/tracker';
-
-const context = React.createContext({});
-
-export const useTracker = () => React.useContext(context);
-
-export const TrackerProvider = ({ children }) => {
- const [config, setConfig] = React.useState(CONFIG);
- const [state, setState] = React.useState(makeEmptyState());
- const [dungeons, setDungeons] = React.useState(DUNGEONS);
-
- React.useEffect(() => {
- const newDungeons = DUNGEONS.map(dungeon => {
- const newDungeon = JSON.parse(JSON.stringify(dungeon));
- if (config.wildMap && dungeon.map) {
- ++newDungeon.items;
- }
- if (config.wildCompass && dungeon.compass) {
- ++newDungeon.items;
- }
- if (config.wildSmall) {
- newDungeon.items += dungeon.sk;
- }
- if (config.wildBig && dungeon.bk && !dungeon.dropBk) {
- ++newDungeon.items;
- }
- if (!config.bossShuffle && dungeon.boss) {
- newDungeon.bosses = [dungeon.boss];
- }
- return newDungeon;
- });
- setDungeons(newDungeons);
- }, [config]);
-
- const value = React.useMemo(() => {
- return { config, setConfig, dungeons, setState, state };
- }, [config, dungeons, state]);
-
- return <context.Provider value={value}>
- {children}
- </context.Provider>;
-};
-
-TrackerProvider.propTypes = {
- children: PropTypes.node,
-};