gamja/components/buffer-list.js
2021-05-31 17:39:37 +02:00

56 lines
1.4 KiB
JavaScript

import * as irc from "../lib/irc.js";
import { html, Component } from "../lib/index.js";
import { BufferType, Unread, getBufferURL, getNetworkName } from "../state.js";
function BufferItem(props) {
function handleClick(event) {
event.preventDefault();
props.onClick();
}
var name = props.buffer.name;
if (props.buffer.type == BufferType.SERVER) {
name = getNetworkName(props.network, props.bouncerNetwork, props.isBouncer);
}
var classes = ["type-" + props.buffer.type];
if (props.active) {
classes.push("active");
}
if (props.buffer.unread != Unread.NONE) {
classes.push("unread-" + props.buffer.unread);
}
return html`
<li class="${classes.join(" ")}">
<a href=${getBufferURL(props.buffer)} onClick=${handleClick}>${name}</a>
</li>
`;
}
export default function BufferList(props) {
var items = Array.from(props.buffers.values()).map((buf) => {
var network = props.networks.get(buf.network);
var bouncerNetwork = null;
var bouncerNetID = network.isupport.get("BOUNCER_NETID");
if (bouncerNetID) {
bouncerNetwork = props.bouncerNetworks.get(bouncerNetID);
}
return html`
<${BufferItem}
key=${buf.id}
buffer=${buf}
network=${network}
isBouncer=${props.isBouncer}
bouncerNetwork=${bouncerNetwork}
onClick=${() => props.onBufferClick(buf)}
active=${props.activeBuffer == buf.id}
/>
`;
});
return html`<ul>${items}</ul>`;
}