import type { NuzlockeRules } from '../types/rules' import { RULE_DEFINITIONS, DEFAULT_RULES } from '../types/rules' import { RuleToggle } from './RuleToggle' interface RulesConfigurationProps { rules: NuzlockeRules onChange: (rules: NuzlockeRules) => void onReset?: (() => void) | undefined hiddenRules?: Set | undefined } export function RulesConfiguration({ rules, onChange, onReset, hiddenRules, }: RulesConfigurationProps) { const visibleRules = hiddenRules ? RULE_DEFINITIONS.filter((r) => !hiddenRules.has(r.key)) : RULE_DEFINITIONS const coreRules = visibleRules.filter((r) => r.category === 'core') const playstyleRules = visibleRules.filter((r) => r.category === 'playstyle') const handleRuleChange = (key: keyof NuzlockeRules, value: boolean) => { onChange({ ...rules, [key]: value }) } const handleResetToDefault = () => { onChange(DEFAULT_RULES) onReset?.() } const enabledCount = visibleRules.filter((r) => rules[r.key]).length const totalCount = visibleRules.length return (

Rules Configuration

{enabledCount} of {totalCount} rules enabled

Core Rules

The fundamental rules of a Nuzlocke challenge

{coreRules.map((rule) => ( handleRuleChange(rule.key, value)} /> ))}

Playstyle

Describe how you're playing — doesn't affect tracker behavior

{playstyleRules.map((rule) => ( handleRuleChange(rule.key, value)} /> ))}
) }