2021-03-02 22:46:48 +01:00
|
|
|
import * as irc from "../lib/irc.js";
|
|
|
|
import { html, Component } from "../lib/index.js";
|
2021-05-31 17:39:37 +02:00
|
|
|
import { BufferType, Unread, getBufferURL, getNetworkName } from "../state.js";
|
2021-01-22 11:43:47 +01:00
|
|
|
|
2020-06-18 14:23:08 +02:00
|
|
|
function BufferItem(props) {
|
|
|
|
function handleClick(event) {
|
|
|
|
event.preventDefault();
|
|
|
|
props.onClick();
|
|
|
|
}
|
|
|
|
|
|
|
|
var name = props.buffer.name;
|
2020-06-26 10:35:38 +02:00
|
|
|
if (props.buffer.type == BufferType.SERVER) {
|
2021-03-08 18:15:04 +01:00
|
|
|
name = getNetworkName(props.network, props.bouncerNetwork, props.isBouncer);
|
2020-06-18 14:23:08 +02:00
|
|
|
}
|
|
|
|
|
2021-01-23 12:04:58 +01:00
|
|
|
var classes = ["type-" + props.buffer.type];
|
|
|
|
if (props.active) {
|
|
|
|
classes.push("active");
|
|
|
|
}
|
2020-06-24 16:56:28 +02:00
|
|
|
if (props.buffer.unread != Unread.NONE) {
|
2021-01-23 12:04:58 +01:00
|
|
|
classes.push("unread-" + props.buffer.unread);
|
2020-06-24 16:56:28 +02:00
|
|
|
}
|
|
|
|
|
2020-06-18 14:23:08 +02:00
|
|
|
return html`
|
2021-01-23 12:04:58 +01:00
|
|
|
<li class="${classes.join(" ")}">
|
2020-07-15 18:47:33 +02:00
|
|
|
<a href=${getBufferURL(props.buffer)} onClick=${handleClick}>${name}</a>
|
2020-06-18 14:23:08 +02:00
|
|
|
</li>
|
|
|
|
`;
|
|
|
|
}
|
|
|
|
|
2020-06-26 14:40:27 +02:00
|
|
|
|
2020-06-18 14:23:08 +02:00
|
|
|
export default function BufferList(props) {
|
2021-01-22 21:01:03 +01:00
|
|
|
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`
|
2021-05-31 17:34:36 +02:00
|
|
|
<${BufferItem}
|
|
|
|
key=${buf.id}
|
|
|
|
buffer=${buf}
|
|
|
|
network=${network}
|
|
|
|
isBouncer=${props.isBouncer}
|
|
|
|
bouncerNetwork=${bouncerNetwork}
|
|
|
|
onClick=${() => props.onBufferClick(buf)}
|
|
|
|
active=${props.activeBuffer == buf.id}
|
|
|
|
/>
|
2021-01-22 21:01:03 +01:00
|
|
|
`;
|
|
|
|
});
|
|
|
|
|
|
|
|
return html`<ul>${items}</ul>`;
|
2020-06-18 14:23:08 +02:00
|
|
|
}
|