cordis/client/webapp/elements/channel.ts

56 lines
2.3 KiB
TypeScript
Raw Normal View History

2021-10-30 17:26:41 +00:00
import ElementsUtil from './require/elements-util.js';
import BaseElements from './require/base-elements.js';
import ClientController from '../client-controller';
import { Channel } from '../data-types';
import createModifyChannelOverlay from './overlay-modify-channel.js';
import UI from '../ui.js';
import Actions from '../actions.js';
import Q from '../q-module.js';
export default function createChannel(document: Document, q: Q, ui: UI, actions: Actions, server: ClientController, channel: Channel) {
let element = q.create({ class: 'channel text', 'meta-id': channel.id, 'meta-server-id': server.id, content: [
// Scraped directly from discord (#)
{ class: 'icon', content: BaseElements.TEXT_CHANNEL_ICON },
{ class: 'name', content: channel.name },
{ class: 'modify', content: BaseElements.COG }
] }) as HTMLElement;
element.addEventListener('click', async () => {
if (element.classList.contains('active')) return;
await ui.setActiveChannel(server, channel);
await actions.fetchAndUpdateMessagesRecent(q, server, channel);
q.$('#text-input').focus();
});
let modifyContextElement = q.create({ class: 'context', content: {
class: 'above', content: [
{ class: 'content text', content: 'Modify Channel' },
{ class: 'tab', content: BaseElements.TAB_BELOW }
]
}}) as HTMLElement;
q.$$$(element, '.modify').addEventListener('click', async (e) => {
e.stopPropagation();
if (modifyContextElement.parentElement) {
modifyContextElement.parentElement.removeChild(modifyContextElement);
}
let modifyOverlay = createModifyChannelOverlay(document, q, server, channel);
document.body.appendChild(modifyOverlay);
q.$$$(modifyOverlay, '.text-input.channel-name').focus();
ElementsUtil.setCursorToEnd(q.$$$(modifyOverlay, '.text-input.channel-name'));
});
q.$$$(element, '.modify').addEventListener('mouseenter', () => {
document.body.appendChild(modifyContextElement);
ElementsUtil.alignContextElement(modifyContextElement, q.$$$(element, '.modify'), { bottom: 'top', centerX: 'centerX' });
});
q.$$$(element, '.modify').addEventListener('mouseleave', () => {
if (modifyContextElement.parentElement) {
modifyContextElement.parentElement.removeChild(modifyContextElement);
}
});
return element;
2021-10-30 17:26:41 +00:00
}