import React from "react"; import { connect, DispatchProp } from "react-redux"; import { Link as RouterLink } from "react-router-dom"; import { Tooltip } from "@dndbeyond/character-common-components/es"; import { CampaignSummary, LightBuilderSvg, ThemedLongRestSvg, ThemedShareSvg, ThemedShortRestSvg, } from "@dndbeyond/character-components/es"; import { CampaignDataContract, CharacterPreferences, characterSelectors, CharacterStatusSlug, CharacterTheme, Constants, Item, ItemUtils, rulesEngineSelectors, } 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 { GameLogState } from "../../../Shared/stores/typings"; import WatchTourDialog from "../../components/WatchTourDialog"; import { sheetAppSelectors } from "../../selectors"; import { SheetAppState } from "../../typings"; import CharacterHeaderInfo from "../CharacterHeaderInfo"; interface Props extends DispatchProp { campaign: CampaignDataContract | null; builderUrl: string; items: Array; preferences: CharacterPreferences; theme: CharacterTheme; isReadonly: boolean; gameLog: GameLogState; status: CharacterStatusSlug | null; paneHistoryStart: PaneInfo["paneHistoryStart"]; } class CharacterHeaderDesktop extends React.PureComponent { constructor(props: Props) { super(props); } handleCampaignShow = (): void => { const { paneHistoryStart } = this.props; paneHistoryStart(PaneComponentEnum.CAMPAIGN); }; handleShortResetClick = (evt: React.MouseEvent): void => { const { paneHistoryStart } = this.props; evt.stopPropagation(); evt.nativeEvent.stopImmediatePropagation(); paneHistoryStart(PaneComponentEnum.SHORT_REST); }; handleLongResetClick = (evt: React.MouseEvent): void => { const { paneHistoryStart } = this.props; evt.stopPropagation(); evt.nativeEvent.stopImmediatePropagation(); paneHistoryStart(PaneComponentEnum.LONG_REST); }; handleShareClick = (evt: React.MouseEvent): void => { const { paneHistoryStart } = this.props; evt.stopPropagation(); evt.nativeEvent.stopImmediatePropagation(); paneHistoryStart(PaneComponentEnum.SHARE_URL); }; hasMagicItem = (): boolean => { const { items } = this.props; return !!items.find((item) => ItemUtils.isMagic(item)); }; renderSideContent = (): React.ReactNode => { const { builderUrl, campaign, preferences, isReadonly, theme, gameLog, status, } = this.props; if (isReadonly) { if (status === CharacterStatusSlug.PREMADE) { return ; } if (!campaign) { return null; } return ( ); } return ( {preferences !== null && preferences.privacyType === Constants.PreferencePrivacyTypeEnum.PUBLIC && (
Share
)}
Short Rest
Long Rest
{/*{this.hasMagicItem() &&*/} {/*
*/} {/*
*/} {/**/} {/*Dawn*/} {/*
*/} {/*
*/} {/*}*/} {campaign !== null && ( )}
); }; render() { return (
{this.renderSideContent()}
); } } function mapStateToProps(state: SheetAppState) { return { builderUrl: sheetAppSelectors.getBuilderUrl(state), campaign: rulesEngineSelectors.getCampaign(state), items: rulesEngineSelectors.getInventory(state), preferences: rulesEngineSelectors.getCharacterPreferences(state), theme: rulesEngineSelectors.getCharacterTheme(state), isReadonly: appEnvSelectors.getIsReadonly(state), gameLog: appEnvSelectors.getGameLog(state), status: characterSelectors.getStatusSlug(state), }; } const CharacterHeaderDesktopContainer = (props) => { const { pane: { paneHistoryStart }, } = useSidebar(); return ( ); }; export default connect(mapStateToProps)(CharacterHeaderDesktopContainer);