/** * Copyright (C) 2019 Simon Redman * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License or (at your option) version 3 or any later version * accepted by the membership of KDE e.V. (or its successor approved * by the membership of KDE e.V.), which shall act as a proxy * defined in Section 14 of version 3 of the license. * * 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef SMSHELPER_H #define SMSHELPER_H #include #include #include #include "interfaces/conversationmessage.h" #include "kdeconnectsms_export.h" Q_DECLARE_LOGGING_CATEGORY(KDECONNECT_SMS_SMSHELPER) class KDECONNECTSMSAPPLIB_EXPORT SmsHelper { public: enum CountryCode { Australia, CzechRepublic, Other, // I only care about a few country codes }; /** * Return true to indicate the two phone numbers should be considered the same, false otherwise */ static bool isPhoneNumberMatch(const QString& phone1, const QString& phone2); /** * Return true to indicate the two phone numbers should be considered the same, false otherwise * Requires canonicalized phone numbers as inputs */ static bool isPhoneNumberMatchCanonicalized(const QString& canonicalPhone1, const QString& canonicalPhone2); /** * See inline comments for how short codes are determined * All information from https://en.wikipedia.org/wiki/Short_code */ static bool isShortCode(const QString& canonicalNumber, const CountryCode& country); /** * Try to guess the country code from the passed number */ static CountryCode determineCountryCode(const QString& canonicalNumber); /** * Simplify a phone number to a known form */ static QString canonicalizePhoneNumber(const QString& phoneNumber); /** * Get the data for a particular person given their contact address */ static KPeople::PersonData* lookupPersonByAddress(const QString& address); /** * Make an icon which combines the many icons * * This mimics what Android does: * If there is only one icon, use that one * If there are two icons, put one in the top-left corner and one in the bottom right * If there are three, put one in the middle of the top and the remaining two in the bottom * If there are four or more, put one in each corner (If more than four, some will be left out) */ static QIcon combineIcons(const QList& icons); /** * Get a combination of all the addresses as a comma-separated list of: * - The KPeople contact's name (if known) * - The address (if the contact is not known) */ static QString getTitleForAddresses(const QList& addresses); /** * Get a combined icon for all contacts by finding: * - The KPeople contact's icon (if known) * - A generic icon * and then using SmsHelper::combineIcons */ static QIcon getIconForAddresses(const QList& addresses); private: SmsHelper(){}; ~SmsHelper(){}; }; #endif // SMSHELPER_H