/** * This file is part of Threema Web. * * Threema Web is free software: you can redistribute it and/or modify it * under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or (at * your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero * General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Threema Web. If not, see . */ // User defined type guards are small functions that determine the type of an object. // See https://www.typescriptlang.org/docs/handbook/advanced-types.html#user-defined-type-guards // for more information. /** * Contact receiver type guard */ export function isContactReceiver( receiver: threema.BaseReceiver, ): receiver is threema.ContactReceiver { return receiver.type === 'contact'; } /** * Group receiver type guard */ export function isGroupReceiver( receiver: threema.BaseReceiver, ): receiver is threema.GroupReceiver { return receiver.type === 'group'; } /** * Distribution list receiver type guard */ export function isDistributionListReceiver( receiver: threema.BaseReceiver, ): receiver is threema.DistributionListReceiver { return receiver.type === 'distributionList'; } /** * Valid receiver types type guard */ export function isValidReceiverType( receiverType: string, ): receiverType is threema.ReceiverType { switch (receiverType) { case 'me': case 'contact': case 'group': case 'distributionList': return true; } return false; } /** * Valid disconnect reasons type guard */ export function isValidDisconnectReason( reason: string, ): reason is threema.DisconnectReason { switch (reason) { case 'stop': case 'delete': case 'disable': case 'replace': return true; } return false; } /** * Text nodes type guard. */ export function isTextNode(node: Node): node is Text { return node.nodeType === node.TEXT_NODE; } /** * Element nodes type guard. */ export function isElementNode(node: Node): node is HTMLElement { return node.nodeType === node.ELEMENT_NODE; } /** * Emoji info type guard. */ export function isEmojiInfo(val: string | threema.EmojiInfo): val is threema.EmojiInfo { return typeof val === 'object' && val.emojiString !== undefined && val.imgPath !== undefined && val.codepoint !== undefined; } /** * Controller model has members. * * This returns true if the `ControllerModel` also implements the `ControllerModelWithMembers` interface. */ export function controllerModelHasMembers( cm: threema.ControllerModel, ): cm is threema.ControllerModel & threema.ControllerModelWithMembers { return cm.receiverType === 'group' || cm.receiverType === 'distributionList'; } /** * Return whether this event is a keyboard event. */ export function isKeyboardEvent(ev: Event): ev is KeyboardEvent { return ev.type === 'keydown' || ev.type === 'keypress' || ev.type === 'keyup'; }