Telegram Web K with changes to work inside I2P
https://web.telegram.i2p/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
3.1 KiB
92 lines
3.1 KiB
4 years ago
|
import type { StickerSet } from "../layer";
|
||
|
import type { MyDocument } from "./appManagers/appDocsManager";
|
||
|
import type { Poll, PollResults } from "./appManagers/appPollsManager";
|
||
|
import type { AppMessagesManager, Dialog, MyDialogFilter } from "./appManagers/appMessagesManager";
|
||
|
import { MOUNT_CLASS_TO } from "./mtproto/mtproto_config";
|
||
|
|
||
|
type BroadcastEvents = {
|
||
|
'user_update': number,
|
||
|
'user_auth': {dcID?: number, id: number},
|
||
|
'peer_changed': number,
|
||
|
|
||
|
'filter_delete': MyDialogFilter,
|
||
|
'filter_update': MyDialogFilter,
|
||
|
|
||
|
'dialog_draft': {peerID: number, draft: any, index: number},
|
||
|
'dialog_unread': {peerID: number, count?: number},
|
||
|
'dialog_flush': {peerID: number},
|
||
|
'dialog_drop': {peerID: number, dialog?: Dialog},
|
||
|
'dialog_migrate': {migrateFrom: number, migrateTo: number},
|
||
|
'dialog_top': Dialog,
|
||
|
'dialog_notify_settings': number,
|
||
|
'dialogs_multiupdate': {[peerID: string]: Dialog},
|
||
|
'dialogs_archived_unread': {count: number},
|
||
|
|
||
|
'history_append': {peerID: number, messageID: number, my?: boolean},
|
||
|
'history_update': {peerID: number, mid: number},
|
||
|
'history_reply_markup': {peerID: number},
|
||
|
'history_multiappend': AppMessagesManager['newMessagesToHandle'],
|
||
|
'history_delete': {peerID: number, msgs: {[mid: number]: true}},
|
||
|
'history_forbidden': number,
|
||
|
'history_reload': number,
|
||
|
'history_request': void,
|
||
|
|
||
|
'message_edit': {peerID: number, id: number, mid: number, justMedia: boolean},
|
||
|
'message_views': {mid: number, views: number},
|
||
|
'message_sent': {tempID: number, mid: number},
|
||
|
'messages_pending': void,
|
||
|
'messages_read': void,
|
||
|
'messages_downloaded': number[],
|
||
|
|
||
|
'stickers_installed': StickerSet.stickerSet,
|
||
|
'stickers_deleted': StickerSet.stickerSet,
|
||
|
|
||
|
'audio_play': {doc: MyDocument, mid: number},
|
||
|
'audio_pause': void,
|
||
|
|
||
|
//'contacts_update': any,
|
||
|
'avatar_update': number,
|
||
|
'chat_full_update': number,
|
||
|
'peer_pinned_message': number,
|
||
|
'poll_update': {poll: Poll, results: PollResults},
|
||
|
'chat_update': number,
|
||
|
'stateSynchronized': void,
|
||
|
'channel_settings': {channelID: number},
|
||
|
'webpage_updated': {id: string, msgs: number[]},
|
||
|
|
||
|
'apiUpdate': any,
|
||
|
'download_progress': any,
|
||
|
//'draft_updated': any,
|
||
|
};
|
||
|
|
||
|
const $rootScope = {
|
||
|
$broadcast: <T extends keyof BroadcastEvents>(name: T, detail?: BroadcastEvents[T]) => {
|
||
|
/* if(name != 'user_update') {
|
||
|
console.debug(dT(), 'Broadcasting ' + name + ' event, with args:', detail);
|
||
|
} */
|
||
|
|
||
|
let myCustomEvent = new CustomEvent(name, {detail});
|
||
|
document.dispatchEvent(myCustomEvent);
|
||
|
},
|
||
|
$on: <T extends keyof BroadcastEvents>(name: T, callback: (e: Omit<CustomEvent, 'detail'> & {detail: BroadcastEvents[T]}) => any) => {
|
||
|
// @ts-ignore
|
||
|
document.addEventListener(name, callback);
|
||
|
},
|
||
|
$off: <T extends keyof BroadcastEvents>(name: T, callback: (e: Omit<CustomEvent, 'detail'> & {detail: BroadcastEvents[T]}) => any) => {
|
||
|
// @ts-ignore
|
||
|
document.removeEventListener(name, callback);
|
||
|
},
|
||
|
|
||
|
selectedPeerID: 0,
|
||
|
myID: 0,
|
||
|
idle: {
|
||
|
isIDLE: false
|
||
|
}
|
||
|
};
|
||
|
|
||
|
$rootScope.$on('user_auth', (e) => {
|
||
|
$rootScope.myID = e.detail.id;
|
||
|
});
|
||
|
|
||
|
MOUNT_CLASS_TO && (MOUNT_CLASS_TO.$rootScope = $rootScope);
|
||
|
export default $rootScope;
|