IRC_Client/components/buffer-list.js

85 lines
2.0 KiB
JavaScript
Raw Permalink Normal View History

import * as irc from "../lib/irc.js";
import { strip as stripANSI } from "../lib/ansi.js";
2024-09-28 21:43:23 +02:00
import { html } from "../lib/index.js";
import { BufferType, Unread, ServerStatus, getBufferURL, getServerName } from "../state.js";
2021-01-22 11:43:47 +01:00
function BufferItem(props) {
function handleClick(event) {
event.preventDefault();
props.onClick();
}
2021-10-17 19:33:02 +02:00
function handleMouseDown(event) {
if (event.button === 1) { // middle click
event.preventDefault();
props.onClose();
}
}
2021-06-10 18:11:11 +02:00
let name = props.buffer.name;
2024-10-14 00:56:18 +02:00
if (props.buffer.type === BufferType.SERVER) {
name = getServerName(props.server, props.bouncerNetwork);
}
let title;
2021-06-10 18:11:11 +02:00
let classes = ["type-" + props.buffer.type];
if (props.active) {
classes.push("active");
}
2024-10-14 00:56:18 +02:00
if (props.buffer.unread !== Unread.NONE) {
classes.push("unread-" + props.buffer.unread);
2020-06-24 16:56:28 +02:00
}
switch (props.buffer.type) {
case BufferType.SERVER:
let isError = props.server.status === ServerStatus.DISCONNECTED;
if (props.bouncerNetwork && props.bouncerNetwork.error) {
isError = true;
}
if (isError) {
classes.push("error");
}
break;
case BufferType.NICK:
let user = props.server.users.get(name);
if (user && irc.isMeaningfulRealname(user.realname, name)) {
title = stripANSI(user.realname);
}
break;
}
2020-06-24 16:56:28 +02:00
return html`
<li class="${classes.join(" ")}">
2021-10-17 19:33:02 +02:00
<a
href=${getBufferURL(props.buffer)}
title=${title}
2021-10-17 19:33:02 +02:00
onClick=${handleClick}
onMouseDown=${handleMouseDown}
>${name}</a>
</li>
`;
}
export default function BufferList(props) {
2021-06-10 18:11:11 +02:00
let items = Array.from(props.buffers.values()).map((buf) => {
let server = props.servers.get(buf.server);
2021-06-10 18:11:11 +02:00
let bouncerNetwork = null;
if (server.bouncerNetID) {
bouncerNetwork = props.bouncerNetworks.get(server.bouncerNetID);
}
return html`
2021-05-31 17:34:36 +02:00
<${BufferItem}
key=${buf.id}
buffer=${buf}
server=${server}
2021-05-31 17:34:36 +02:00
bouncerNetwork=${bouncerNetwork}
onClick=${() => props.onBufferClick(buf)}
2021-10-17 19:33:02 +02:00
onClose=${() => props.onBufferClose(buf)}
2024-10-14 00:56:18 +02:00
active=${props.activeBuffer === buf.id}
2021-05-31 17:34:36 +02:00
/>
`;
});
return html`<ul>${items}</ul>`;
}