mirror of
https://codeberg.org/emersion/gamja
synced 2025-03-12 23:43:42 +01:00
components/buffer-list: show realname as tooltip
This commit is contained in:
parent
15cc546876
commit
038cc68ee4
@ -1,4 +1,5 @@
|
|||||||
import * as irc from "../lib/irc.js";
|
import * as irc from "../lib/irc.js";
|
||||||
|
import { strip as stripANSI } from "../lib/ansi.js";
|
||||||
import { html, Component } from "../lib/index.js";
|
import { html, Component } from "../lib/index.js";
|
||||||
import { BufferType, Unread, ServerStatus, getBufferURL, getServerName } from "../state.js";
|
import { BufferType, Unread, ServerStatus, getBufferURL, getServerName } from "../state.js";
|
||||||
|
|
||||||
@ -19,6 +20,7 @@ function BufferItem(props) {
|
|||||||
name = getServerName(props.server, props.bouncerNetwork);
|
name = getServerName(props.server, props.bouncerNetwork);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let title;
|
||||||
let classes = ["type-" + props.buffer.type];
|
let classes = ["type-" + props.buffer.type];
|
||||||
if (props.active) {
|
if (props.active) {
|
||||||
classes.push("active");
|
classes.push("active");
|
||||||
@ -26,7 +28,8 @@ function BufferItem(props) {
|
|||||||
if (props.buffer.unread != Unread.NONE) {
|
if (props.buffer.unread != Unread.NONE) {
|
||||||
classes.push("unread-" + props.buffer.unread);
|
classes.push("unread-" + props.buffer.unread);
|
||||||
}
|
}
|
||||||
if (props.buffer.type === BufferType.SERVER) {
|
switch (props.buffer.type) {
|
||||||
|
case BufferType.SERVER:
|
||||||
let isError = props.server.status === ServerStatus.DISCONNECTED;
|
let isError = props.server.status === ServerStatus.DISCONNECTED;
|
||||||
if (props.bouncerNetwork && props.bouncerNetwork.error) {
|
if (props.bouncerNetwork && props.bouncerNetwork.error) {
|
||||||
isError = true;
|
isError = true;
|
||||||
@ -34,12 +37,20 @@ function BufferItem(props) {
|
|||||||
if (isError) {
|
if (isError) {
|
||||||
classes.push("error");
|
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
return html`
|
return html`
|
||||||
<li class="${classes.join(" ")}">
|
<li class="${classes.join(" ")}">
|
||||||
<a
|
<a
|
||||||
href=${getBufferURL(props.buffer)}
|
href=${getBufferURL(props.buffer)}
|
||||||
|
title=${title}
|
||||||
onClick=${handleClick}
|
onClick=${handleClick}
|
||||||
onMouseDown=${handleMouseDown}
|
onMouseDown=${handleMouseDown}
|
||||||
>${name}</a>
|
>${name}</a>
|
||||||
@ -47,7 +58,6 @@ function BufferItem(props) {
|
|||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export default function BufferList(props) {
|
export default function BufferList(props) {
|
||||||
let items = Array.from(props.buffers.values()).map((buf) => {
|
let items = Array.from(props.buffers.values()).map((buf) => {
|
||||||
let server = props.servers.get(buf.server);
|
let server = props.servers.get(buf.server);
|
||||||
|
@ -41,7 +41,7 @@ class MemberItem extends Component {
|
|||||||
`;
|
`;
|
||||||
};
|
};
|
||||||
|
|
||||||
let title = null;
|
let title;
|
||||||
let user = this.props.user;
|
let user = this.props.user;
|
||||||
let classes = ["nick"];
|
let classes = ["nick"];
|
||||||
if (user) {
|
if (user) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user