import React from "react"; import { connect, DispatchProp } from "react-redux"; import { rulesEngineSelectors, characterActions, characterSelectors, CharacterStatusSlug, Constants, HitPointInfo, RuleData, } from "@dndbeyond/character-rules-engine/es"; import { useSidebar } from "~/contexts/Sidebar"; import { PaneInfo } from "~/contexts/Sidebar/Sidebar"; import { PaneComponentEnum } from "~/subApps/sheet/components/Sidebar/types"; import { appEnvSelectors } from "../../../Shared/selectors"; import StatusSummaryMobile from "../../components/StatusSummaryMobile"; import WatchTourDialog from "../../components/WatchTourDialog"; import { SheetAppState } from "../../typings"; import CharacterHeaderInfo from "../CharacterHeaderInfo"; interface Props extends DispatchProp { hitPointInfo: HitPointInfo; fails: number; successes: number; deathCause: Constants.DeathCauseEnum; inspiration: boolean; ruleData: RuleData; isReadonly: boolean; status: CharacterStatusSlug | null; paneHistoryStart: PaneInfo["paneHistoryStart"]; } class CharacterHeaderMobile extends React.PureComponent { handleHealthSummaryClick = (): void => { const { paneHistoryStart, isReadonly } = this.props; if (!isReadonly) { paneHistoryStart(PaneComponentEnum.HEALTH_MANAGE); } }; handleInspirationClick = (): void => { const { inspiration, dispatch } = this.props; dispatch(characterActions.inspirationSet(!inspiration)); }; render() { const { hitPointInfo, fails, successes, deathCause, inspiration, ruleData, isReadonly, status, } = this.props; return (
{isReadonly && status === CharacterStatusSlug.PREMADE ? (
) : (
)}
); } } function mapStateToProps(state: SheetAppState) { return { hitPointInfo: rulesEngineSelectors.getHitPointInfo(state), fails: rulesEngineSelectors.getDeathSavesFailCount(state), successes: rulesEngineSelectors.getDeathSavesSuccessCount(state), inspiration: rulesEngineSelectors.getInspiration(state), ruleData: rulesEngineSelectors.getRuleData(state), deathCause: rulesEngineSelectors.getDeathCause(state), isReadonly: appEnvSelectors.getIsReadonly(state), status: characterSelectors.getStatusSlug(state), }; } const CharacterHeaderMobileContainer = (props) => { const { pane: { paneHistoryStart }, } = useSidebar(); return ( ); }; export default connect(mapStateToProps)(CharacterHeaderMobileContainer);