import { html } from "../lib/index.js"; import linkify from "../lib/linkify.js"; import { strip as stripANSI } from "../lib/ansi.js"; import { BufferType, ServerStatus, getServerName } from "../state.js"; import * as irc from "../lib/irc.js"; const UserStatus = { HERE: "here", GONE: "gone", OFFLINE: "offline", }; function NickStatus(props) { let textMap = { [UserStatus.HERE]: "User is online", [UserStatus.GONE]: "User is away", [UserStatus.OFFLINE]: "User is offline", }; let text = textMap[props.status]; return html``; } export default function BufferHeader(props) { let fullyConnected = props.server.status === ServerStatus.REGISTERED; if (props.bouncerNetwork) { fullyConnected = fullyConnected && props.bouncerNetwork.state === "connected"; } let description = null, actions = []; switch (props.buffer.type) { case BufferType.SERVER: switch (props.server.status) { case ServerStatus.DISCONNECTED: description = "Disconnected"; break; case ServerStatus.CONNECTING: description = "Connecting..."; break; case ServerStatus.REGISTERING: description = "Logging in..."; break; case ServerStatus.REGISTERED: if (props.bouncerNetwork) { switch (props.bouncerNetwork.state) { case "disconnected": description = "Bouncer disconnected from network"; if (props.bouncerNetwork.error) { description += ": " + props.bouncerNetwork.error; } break; case "connecting": description = "Bouncer connecting to network..."; break; case "connected": // host can be undefined e.g. when using UNIX domain sockets description = `Connected to ${props.bouncerNetwork.host || "network"}`; break; } } else if (props.buffer.serverInfo) { let serverInfo = props.buffer.serverInfo; description = `Connected to ${serverInfo.name}`; } else { description = "Connected"; } break; } let joinButton = html` `; let reconnectButton = html` `; let settingsButton = html` `; if (props.server.isBouncer) { if (props.server.bouncerNetID) { if (fullyConnected) { actions.push(joinButton); } if (props.server.status === ServerStatus.REGISTERED) { actions.push(html` `); } } else { if (fullyConnected) { actions.push(html` `); } else if (props.server.status === ServerStatus.DISCONNECTED) { actions.push(reconnectButton); } actions.push(settingsButton); } } else { if (fullyConnected) { actions.push(joinButton); } else if (props.server.status === ServerStatus.DISCONNECTED) { actions.push(reconnectButton); } actions.push(settingsButton); } break; case BufferType.CHANNEL: if (props.buffer.topic) { description = linkify(stripANSI(props.buffer.topic), props.onChannelClick); } if (props.buffer.joined) { actions.push(html` `); } else { if (fullyConnected) { actions.push(html` `); } actions.push(html` `); } break; case BufferType.NICK: if (props.user) { let status = UserStatus.HERE; if (props.user.offline) { status = UserStatus.OFFLINE; } else if (props.user.away) { status = UserStatus.GONE; } let realname = props.buffer.name; if (irc.isMeaningfulRealname(props.user.realname, props.buffer.name)) { realname = stripANSI(props.user.realname || ""); } let details = []; if (props.user.username && props.user.hostname) { details.push(`${props.user.username}@${props.user.hostname}`); } if (props.user.account) { let desc = `This user is verified and has logged in to the server with the account ${props.user.account}.`; let item; if (props.user.account === props.buffer.name) { item = "authenticated"; } else { item = `authenticated as ${props.user.account}`; } details.push(html`${item}`); } else if (props.server.reliableUserAccounts) { // If the server supports MONITOR and WHOX, we can faithfully // keep user.account up-to-date for user queries let desc = "This user has not been verified and is not logged in."; details.push(html`unauthenticated`); } if (props.user.operator) { let desc = "This user is a server operator, they have administrator privileges."; details.push(html`server operator`); } if (props.user.bot) { let desc = "This user is an automated bot."; details.push(html`bot`); } details = details.map((item, i) => { if (i === 0) { return item; } return [", ", item]; }); if (details.length > 0) { details = ["(", details, ")"]; } description = html`<${NickStatus} status=${status}/> ${realname} ${details}`; } actions = html` `; break; } let name = props.buffer.name; if (props.buffer.type === BufferType.SERVER) { name = getServerName(props.server, props.bouncerNetwork); } return html`
${name}
${description ? html`
${description}
` : null}
${actions}
`; }