mirror of
https://github.com/zulip/zulip-desktop.git
synced 2025-10-24 00:23:36 +00:00
67 lines
1.8 KiB
TypeScript
67 lines
1.8 KiB
TypeScript
import type {HTML} from "../../../common/html";
|
|
import {html} from "../../../common/html";
|
|
import {ipcRenderer} from "../typed-ipc-renderer";
|
|
import * as SystemUtil from "../utils/system-util";
|
|
|
|
import {generateNodeFromHTML} from "./base";
|
|
import type {TabProps} from "./tab";
|
|
import Tab from "./tab";
|
|
|
|
export default class ServerTab extends Tab {
|
|
$el: Element;
|
|
$badge: Element;
|
|
|
|
constructor(props: TabProps) {
|
|
super(props);
|
|
|
|
this.$el = generateNodeFromHTML(this.templateHTML());
|
|
this.props.$root.append(this.$el);
|
|
this.registerListeners();
|
|
this.$badge = this.$el.querySelector(".server-tab-badge")!;
|
|
}
|
|
|
|
templateHTML(): HTML {
|
|
return html`
|
|
<div class="tab" data-tab-id="${this.props.tabIndex}">
|
|
<div class="server-tooltip" style="display:none">
|
|
${this.props.name}
|
|
</div>
|
|
<div class="server-tab-badge"></div>
|
|
<div class="server-tab">
|
|
<img class="server-icons" src="${this.props.icon}" />
|
|
</div>
|
|
<div class="server-tab-shortcut">${this.generateShortcutText()}</div>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
updateBadge(count: number): void {
|
|
if (count > 0) {
|
|
const formattedCount = count > 999 ? "1K+" : count.toString();
|
|
this.$badge.textContent = formattedCount;
|
|
this.$badge.classList.add("active");
|
|
} else {
|
|
this.$badge.classList.remove("active");
|
|
}
|
|
}
|
|
|
|
generateShortcutText(): string {
|
|
// Only provide shortcuts for server [0..9]
|
|
if (this.props.index >= 9) {
|
|
return "";
|
|
}
|
|
|
|
const shownIndex = this.props.index + 1;
|
|
|
|
let shortcutText = "";
|
|
|
|
shortcutText =
|
|
SystemUtil.getOS() === "Mac" ? `⌘ ${shownIndex}` : `Ctrl+${shownIndex}`;
|
|
|
|
// Array index == Shown index - 1
|
|
ipcRenderer.send("switch-server-tab", shownIndex - 1);
|
|
|
|
return shortcutText;
|
|
}
|
|
}
|