Temp
This commit is contained in:
parent
350fc0b19e
commit
c002c43a08
@ -19,6 +19,7 @@ export default class AutocompleteHelper extends EventListenerBase<{
|
|||||||
protected container: HTMLElement;
|
protected container: HTMLElement;
|
||||||
protected list: HTMLElement;
|
protected list: HTMLElement;
|
||||||
protected resetTarget: () => void;
|
protected resetTarget: () => void;
|
||||||
|
protected init?(): void;
|
||||||
|
|
||||||
constructor(appendTo: HTMLElement,
|
constructor(appendTo: HTMLElement,
|
||||||
protected listType: 'xy' | 'x' | 'y',
|
protected listType: 'xy' | 'x' | 'y',
|
||||||
@ -73,6 +74,10 @@ export default class AutocompleteHelper extends EventListenerBase<{
|
|||||||
}
|
}
|
||||||
|
|
||||||
public toggle(hide?: boolean) {
|
public toggle(hide?: boolean) {
|
||||||
|
if(this.init) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
hide = hide === undefined ? this.container.classList.contains('is-visible') && !this.container.classList.contains('backwards') : hide;
|
hide = hide === undefined ? this.container.classList.contains('is-visible') && !this.container.classList.contains('backwards') : hide;
|
||||||
|
|
||||||
if(this.hidden === hide) {
|
if(this.hidden === hide) {
|
||||||
|
21
src/components/chat/autocompleteHelperController.ts
Normal file
21
src/components/chat/autocompleteHelperController.ts
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
import AutocompleteHelper from "./autocompleteHelper";
|
||||||
|
|
||||||
|
export default class AutocompleteHelperController {
|
||||||
|
private helpers: Set<AutocompleteHelper> = new Set();
|
||||||
|
|
||||||
|
public addHelpers(helpers: AutocompleteHelper[]) {
|
||||||
|
for(const helper of helpers) {
|
||||||
|
this.helpers.add(helper);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public toggleHelper(helper: AutocompleteHelper, hide?: boolean) {
|
||||||
|
this.helpers.forEach(h => {
|
||||||
|
if(h !== helper) {
|
||||||
|
helper.toggle(true);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
helper.toggle(hide);
|
||||||
|
}
|
||||||
|
}
|
@ -15,7 +15,7 @@ export default class CommandsHelper extends AutocompleteHelper {
|
|||||||
this.container.classList.add('commands-helper');
|
this.container.classList.add('commands-helper');
|
||||||
}
|
}
|
||||||
|
|
||||||
private init() {
|
protected init() {
|
||||||
this.list = document.createElement('div');
|
this.list = document.createElement('div');
|
||||||
this.list.classList.add('commands-helper-commands');
|
this.list.classList.add('commands-helper-commands');
|
||||||
|
|
||||||
@ -30,7 +30,7 @@ export default class CommandsHelper extends AutocompleteHelper {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public renderCommands(commands: {userId: number, command: BotCommand}[]) {
|
public render(commands: {userId: number, command: BotCommand}[]) {
|
||||||
if(this.init) {
|
if(this.init) {
|
||||||
if(!commands.length) {
|
if(!commands.length) {
|
||||||
return;
|
return;
|
||||||
|
@ -14,7 +14,7 @@ export default class EmojiHelper extends AutocompleteHelper {
|
|||||||
this.container.classList.add('emoji-helper');
|
this.container.classList.add('emoji-helper');
|
||||||
}
|
}
|
||||||
|
|
||||||
private init() {
|
protected init() {
|
||||||
this.list = document.createElement('div');
|
this.list = document.createElement('div');
|
||||||
this.list.classList.add('emoji-helper-emojis', 'super-emojis');
|
this.list.classList.add('emoji-helper-emojis', 'super-emojis');
|
||||||
|
|
||||||
@ -29,7 +29,7 @@ export default class EmojiHelper extends AutocompleteHelper {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public renderEmojis(emojis: string[], waitForKey: boolean) {
|
public render(emojis: string[], waitForKey: boolean) {
|
||||||
if(this.init) {
|
if(this.init) {
|
||||||
if(!emojis.length) {
|
if(!emojis.length) {
|
||||||
return;
|
return;
|
||||||
|
@ -62,6 +62,7 @@ import EmojiHelper from './emojiHelper';
|
|||||||
import setRichFocus from '../../helpers/dom/setRichFocus';
|
import setRichFocus from '../../helpers/dom/setRichFocus';
|
||||||
import SearchIndex from '../../lib/searchIndex';
|
import SearchIndex from '../../lib/searchIndex';
|
||||||
import CommandsHelper from './commandsHelper';
|
import CommandsHelper from './commandsHelper';
|
||||||
|
import AutocompleteHelperController from './autocompleteHelperController';
|
||||||
|
|
||||||
const RECORD_MIN_TIME = 500;
|
const RECORD_MIN_TIME = 500;
|
||||||
const POSTING_MEDIA_NOT_ALLOWED = 'Posting media content isn\'t allowed in this group.';
|
const POSTING_MEDIA_NOT_ALLOWED = 'Posting media content isn\'t allowed in this group.';
|
||||||
@ -132,6 +133,7 @@ export default class ChatInput {
|
|||||||
readonly executedHistory: string[] = [];
|
readonly executedHistory: string[] = [];
|
||||||
private canUndoFromHTML = '';
|
private canUndoFromHTML = '';
|
||||||
|
|
||||||
|
private autocompleteHelperController: AutocompleteHelperController;
|
||||||
private commandsHelper: CommandsHelper;
|
private commandsHelper: CommandsHelper;
|
||||||
private emojiHelper: EmojiHelper;
|
private emojiHelper: EmojiHelper;
|
||||||
private stickersHelper: StickersHelper;
|
private stickersHelper: StickersHelper;
|
||||||
@ -366,9 +368,12 @@ export default class ChatInput {
|
|||||||
this.newMessageWrapper.append(...[this.btnToggleEmoticons, this.inputMessageContainer, this.btnScheduled, this.attachMenu, this.recordTimeEl, this.fileInput].filter(Boolean));
|
this.newMessageWrapper.append(...[this.btnToggleEmoticons, this.inputMessageContainer, this.btnScheduled, this.attachMenu, this.recordTimeEl, this.fileInput].filter(Boolean));
|
||||||
|
|
||||||
this.rowsWrapper.append(this.replyElements.container);
|
this.rowsWrapper.append(this.replyElements.container);
|
||||||
this.commandsHelper = new CommandsHelper(this.rowsWrapper);
|
this.autocompleteHelperController = new AutocompleteHelperController();
|
||||||
this.emojiHelper = new EmojiHelper(this.rowsWrapper, this);
|
this.autocompleteHelperController.addHelpers([
|
||||||
this.stickersHelper = new StickersHelper(this.rowsWrapper);
|
this.commandsHelper = new CommandsHelper(this.rowsWrapper),
|
||||||
|
this.emojiHelper = new EmojiHelper(this.rowsWrapper, this),
|
||||||
|
this.stickersHelper = new StickersHelper(this.rowsWrapper)
|
||||||
|
]);
|
||||||
this.rowsWrapper.append(this.newMessageWrapper);
|
this.rowsWrapper.append(this.newMessageWrapper);
|
||||||
|
|
||||||
this.btnCancelRecord = ButtonIcon('delete danger btn-circle z-depth-1 btn-record-cancel');
|
this.btnCancelRecord = ButtonIcon('delete danger btn-circle z-depth-1 btn-record-cancel');
|
||||||
@ -1271,7 +1276,7 @@ export default class ChatInput {
|
|||||||
} else {
|
} else {
|
||||||
this.hideSuggestions()
|
this.hideSuggestions()
|
||||||
}
|
}
|
||||||
} else */ /* if(!matches[1] && matches[2][0] === '/') { // commands
|
} else */ if(!matches[1] && matches[2][0] === '/') { // commands
|
||||||
if(this.chat.peerId > 0) {
|
if(this.chat.peerId > 0) {
|
||||||
this.chat.appProfileManager.getProfileByPeerId(this.chat.peerId).then(full => {
|
this.chat.appProfileManager.getProfileByPeerId(this.chat.peerId).then(full => {
|
||||||
const botInfos: BotInfo.botInfo[] = [].concat(full.bot_info);
|
const botInfos: BotInfo.botInfo[] = [].concat(full.bot_info);
|
||||||
@ -1287,11 +1292,11 @@ export default class ChatInput {
|
|||||||
|
|
||||||
const found = index.search(matches[2]);
|
const found = index.search(matches[2]);
|
||||||
const filtered = Array.from(found).map(command => commands.get(command));
|
const filtered = Array.from(found).map(command => commands.get(command));
|
||||||
this.commandsHelper.renderCommands(filtered);
|
this.commandsHelper.render(filtered);
|
||||||
console.log('found commands', found, filtered);
|
console.log('found commands', found, filtered);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else */ { // emoji
|
} else { // emoji
|
||||||
if(value.match(/^\s*:(.+):\s*$/)) {
|
if(value.match(/^\s*:(.+):\s*$/)) {
|
||||||
this.emojiHelper.toggle(true);
|
this.emojiHelper.toggle(true);
|
||||||
return;
|
return;
|
||||||
@ -1300,7 +1305,7 @@ export default class ChatInput {
|
|||||||
this.appEmojiManager.getBothEmojiKeywords().then(() => {
|
this.appEmojiManager.getBothEmojiKeywords().then(() => {
|
||||||
const q = matches[2].replace(/^:/, '');
|
const q = matches[2].replace(/^:/, '');
|
||||||
const emojis = this.appEmojiManager.searchEmojis(q);
|
const emojis = this.appEmojiManager.searchEmojis(q);
|
||||||
this.emojiHelper.renderEmojis(emojis, matches[2][0] !== ':');
|
this.emojiHelper.render(emojis, matches[2][0] !== ':');
|
||||||
//console.log(emojis);
|
//console.log(emojis);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -90,7 +90,7 @@ export default class StickersHelper extends AutocompleteHelper {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private init() {
|
protected init() {
|
||||||
this.list = document.createElement('div');
|
this.list = document.createElement('div');
|
||||||
this.list.classList.add('stickers-helper-stickers', 'super-stickers');
|
this.list.classList.add('stickers-helper-stickers', 'super-stickers');
|
||||||
|
|
||||||
|
@ -9,18 +9,18 @@
|
|||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover">
|
||||||
|
|
||||||
<!-- do not paste other icons here, only change these. 'icon' type must be single -->
|
<!-- do not paste other icons here, only change these. 'icon' type must be single -->
|
||||||
<link rel="apple-touch-icon" sizes="180x180" href="/assets/img/apple-touch-icon.png?v=jw3mK7G9Ry">
|
<link rel="apple-touch-icon" sizes="180x180" href="assets/img/apple-touch-icon.png?v=jw3mK7G9Ry">
|
||||||
<link rel="icon" type="image/png" sizes="32x32" href="/assets/img/favicon-32x32.png?v=jw3mK7G9Ry">
|
<link rel="icon" type="image/png" sizes="32x32" href="assets/img/favicon-32x32.png?v=jw3mK7G9Ry">
|
||||||
<!--<link rel="icon" type="image/png" sizes="192x192" href="/assets/img/android-chrome-192x192.png?v=jw3mK7G9Ry">
|
<!--<link rel="icon" type="image/png" sizes="192x192" href="assets/img/android-chrome-192x192.png?v=jw3mK7G9Ry">
|
||||||
<link rel="icon" type="image/png" sizes="16x16" href="/assets/img/favicon-16x16.png?v=jw3mK7G9Ry">-->
|
<link rel="icon" type="image/png" sizes="16x16" href="assets/img/favicon-16x16.png?v=jw3mK7G9Ry">-->
|
||||||
<link rel="manifest" href="/assets/img/site.webmanifest?v=jw3mK7G9Ry">
|
<link rel="manifest" href="assets/img/site.webmanifest?v=jw3mK7G9Ry">
|
||||||
<link rel="mask-icon" href="/assets/img/safari-pinned-tab.svg?v=jw3mK7G9Ry" color="#3390ec">
|
<link rel="mask-icon" href="assets/img/safari-pinned-tab.svg?v=jw3mK7G9Ry" color="#3390ec">
|
||||||
<!--<link rel="shortcut icon" href="/assets/img/favicon.ico?v=jw3mK7G9Ry">-->
|
<!--<link rel="shortcut icon" href="assets/img/favicon.ico?v=jw3mK7G9Ry">-->
|
||||||
<meta name="apple-mobile-web-app-title" content="Telegram WebK">
|
<meta name="apple-mobile-web-app-title" content="Telegram WebK">
|
||||||
<meta name="application-name" content="Telegram WebK">
|
<meta name="application-name" content="Telegram WebK">
|
||||||
<meta name="msapplication-TileColor" content="#2d89ef">
|
<meta name="msapplication-TileColor" content="#2d89ef">
|
||||||
<meta name="msapplication-TileImage" content="/assets/img/mstile-144x144.png?v=jw3mK7G9Ry">
|
<meta name="msapplication-TileImage" content="assets/img/mstile-144x144.png?v=jw3mK7G9Ry">
|
||||||
<meta name="msapplication-config" content="/assets/img/browserconfig.xml?v=jw3mK7G9Ry">
|
<meta name="msapplication-config" content="assets/img/browserconfig.xml?v=jw3mK7G9Ry">
|
||||||
<meta name="theme-color" content="#ffffff">
|
<meta name="theme-color" content="#ffffff">
|
||||||
<meta name="color-scheme" content="light">
|
<meta name="color-scheme" content="light">
|
||||||
{{# each htmlWebpackPlugin.files.css }}
|
{{# each htmlWebpackPlugin.files.css }}
|
||||||
|
Loading…
Reference in New Issue
Block a user