2023-07-12 16:01:27 +02:00
|
|
|
import * as React from 'react'
|
|
|
|
|
2023-07-12 16:27:49 +02:00
|
|
|
import type { TalkNPCs } from '@lastres/talk-npc'
|
2023-07-12 16:56:01 +02:00
|
|
|
import type { StateGame, OnWordSelectCallback } from '@lastres/components/game'
|
|
|
|
|
2023-07-12 16:27:49 +02:00
|
|
|
import TalkNPCComponent from '@lastres/components/talk-npc'
|
2023-07-12 16:01:27 +02:00
|
|
|
|
|
|
|
export interface TalkNPCsComponentProps {
|
|
|
|
talkNPCs: TalkNPCs | null
|
|
|
|
websocket: WebSocket | null
|
2023-07-12 16:56:01 +02:00
|
|
|
setStateGame: (set: StateGame) => void
|
|
|
|
setOnWordSelect: (set: OnWordSelectCallback) => void
|
2023-07-12 16:01:27 +02:00
|
|
|
}
|
|
|
|
export default function TalkNPCsComponent (props: TalkNPCsComponentProps): JSX.Element {
|
|
|
|
const npcs = props.talkNPCs
|
|
|
|
if (npcs === null) {
|
|
|
|
return <></>
|
|
|
|
}
|
|
|
|
if (Object.keys(npcs).length < 1) {
|
|
|
|
return <>
|
|
|
|
<p>No hay nadie para hablar ahora.</p>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<p>Disponible para hablar:</p>
|
|
|
|
{
|
|
|
|
Object.keys(npcs).map((identifier) => {
|
|
|
|
const npc = npcs[identifier]
|
2023-07-12 16:27:49 +02:00
|
|
|
return (
|
|
|
|
<TalkNPCComponent key={identifier}
|
|
|
|
npc={npc}
|
2023-07-12 16:56:01 +02:00
|
|
|
websocket={props.websocket}
|
|
|
|
setStateGame={props.setStateGame}
|
|
|
|
setOnWordSelect={props.setOnWordSelect}/>
|
2023-07-12 16:27:49 +02:00
|
|
|
)
|
2023-07-12 16:01:27 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|