2023-06-01 08:45:43 +02:00
|
|
|
import * as React from 'react'
|
2023-06-22 21:54:28 +02:00
|
|
|
|
2023-06-30 19:59:18 +02:00
|
|
|
import type { Action, ActionHash } from '@lastres/action'
|
2023-07-12 16:01:27 +02:00
|
|
|
import type { TalkNPCs } from '@lastres/talk-npc'
|
|
|
|
import type { StateGame, OnWordSelectCallback } from '@lastres/components/game'
|
2023-07-09 18:41:21 +02:00
|
|
|
|
2023-07-02 06:35:14 +02:00
|
|
|
import OutputPacketExecuteAction from '@lastres/output-packet/execute_action'
|
2023-06-30 19:59:18 +02:00
|
|
|
|
2023-06-22 21:54:28 +02:00
|
|
|
import PresentationItem from '@lastres/components/presentation-item'
|
|
|
|
import Presentation from '@lastres/components/presentation'
|
2023-07-12 16:01:27 +02:00
|
|
|
import TalkNPCsComponent from '@lastres/components/talk-npcs'
|
2023-06-22 21:54:28 +02:00
|
|
|
|
|
|
|
export interface BottomPanelProps {
|
|
|
|
websocket: WebSocket | null
|
2023-06-30 19:59:18 +02:00
|
|
|
actionHash: ActionHash | null
|
2023-07-09 18:41:21 +02:00
|
|
|
talkNPCs: TalkNPCs | null
|
2023-07-12 16:01:27 +02:00
|
|
|
setStateGame: (set: StateGame) => void
|
|
|
|
setOnWordSelect: (set: OnWordSelectCallback) => void
|
2023-06-30 19:59:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface Style {
|
|
|
|
background?: string
|
2023-06-22 21:54:28 +02:00
|
|
|
}
|
|
|
|
|
2023-06-30 19:59:18 +02:00
|
|
|
export default function BottomPanel (props: BottomPanelProps): JSX.Element {
|
|
|
|
const actionHash = props.actionHash
|
2023-07-12 16:01:27 +02:00
|
|
|
function printListActions (): JSX.Element {
|
2023-06-30 19:59:18 +02:00
|
|
|
if (actionHash === null) {
|
|
|
|
return <></>
|
|
|
|
}
|
|
|
|
const listOfActionKeys = Object.keys(actionHash).sort((a, b) => {
|
|
|
|
const isDisabledComparisionValue: number = +actionHash[a].is_disabled - +actionHash[b].is_disabled
|
|
|
|
if (isDisabledComparisionValue !== 0) {
|
|
|
|
return isDisabledComparisionValue
|
|
|
|
}
|
|
|
|
if (actionHash[a].name < actionHash[b].name) {
|
|
|
|
return -1
|
|
|
|
}
|
|
|
|
if (actionHash[a].name > actionHash[b].name) {
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
})
|
|
|
|
function printDisabledReason (action: Action): JSX.Element {
|
|
|
|
if (!action.is_disabled || action.disabled_reason === null) {
|
|
|
|
return <></>
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<p className="disabled-reason" style={{ color: 'red' }}>{action.disabled_reason}</p>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
return <>
|
|
|
|
<p>Acciones disponibles.</p>
|
|
|
|
{
|
|
|
|
listOfActionKeys.map((key) => {
|
|
|
|
const style: Style = {}
|
|
|
|
const action = actionHash[key]
|
|
|
|
if (action.is_disabled) {
|
|
|
|
style.background = 'lightgray'
|
|
|
|
}
|
2023-07-02 06:35:14 +02:00
|
|
|
function onClick (): void {
|
|
|
|
if (action.is_disabled) {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if (props.websocket !== null) {
|
|
|
|
new OutputPacketExecuteAction(action.identifier)
|
|
|
|
.send(props.websocket)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return <a onClick={onClick} className="action" style={style} key={action.identifier}>
|
2023-06-30 19:59:18 +02:00
|
|
|
<p>{action.name}</p>
|
|
|
|
{
|
|
|
|
printDisabledReason(action)
|
|
|
|
}
|
2023-07-02 06:35:14 +02:00
|
|
|
</a>
|
2023-06-30 19:59:18 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
</>
|
|
|
|
}
|
2023-06-01 08:45:43 +02:00
|
|
|
return (
|
2023-06-22 21:54:28 +02:00
|
|
|
<Presentation>
|
|
|
|
<PresentationItem>
|
2023-06-30 19:59:18 +02:00
|
|
|
{
|
|
|
|
printListActions()
|
|
|
|
}
|
2023-06-29 09:04:38 +02:00
|
|
|
</PresentationItem>
|
|
|
|
<PresentationItem>
|
2023-07-12 16:01:27 +02:00
|
|
|
<TalkNPCsComponent websocket={props.websocket}
|
2023-07-12 16:56:01 +02:00
|
|
|
talkNPCs={props.talkNPCs}
|
|
|
|
setStateGame={props.setStateGame}
|
|
|
|
setOnWordSelect={props.setOnWordSelect}/>
|
2023-06-29 09:04:38 +02:00
|
|
|
</PresentationItem>
|
|
|
|
<PresentationItem>
|
2023-06-22 21:54:28 +02:00
|
|
|
</PresentationItem>
|
|
|
|
</Presentation>
|
2023-06-01 08:45:43 +02:00
|
|
|
)
|
|
|
|
}
|