mirror of
https://github.com/AyuGram/AyuGramDesktop.git
synced 2025-04-16 14:17:12 +02:00
Added ability to extract pattern groups from incomplete phone number.
This commit is contained in:
parent
10c8162575
commit
6ff0cb853d
3 changed files with 37 additions and 7 deletions
|
@ -343,8 +343,27 @@ FormatResult CountriesInstance::format(FormatArgs args) {
|
|||
return FormatResult{ .formatted = phoneNumber };
|
||||
}
|
||||
|
||||
const auto formattedPart = phoneNumber.mid(
|
||||
bestCallingCodePtr->callingCode.size());
|
||||
const auto codeSize = int(bestCallingCodePtr->callingCode.size());
|
||||
|
||||
if (args.onlyGroups && args.incomplete) {
|
||||
auto groups = args.skipCode
|
||||
? QVector<int>()
|
||||
: QVector<int>{ codeSize };
|
||||
auto groupSize = 0;
|
||||
for (const auto &c : bestCallingCodePtr->patterns.front()) {
|
||||
if (c == ' ') {
|
||||
groups.push_back(base::take(groupSize));
|
||||
} else {
|
||||
groupSize++;
|
||||
}
|
||||
}
|
||||
if (groupSize) {
|
||||
groups.push_back(base::take(groupSize));
|
||||
}
|
||||
return FormatResult{ .groups = std::move(groups) };
|
||||
}
|
||||
|
||||
const auto formattedPart = phoneNumber.mid(codeSize);
|
||||
auto formattedResult = formattedPart;
|
||||
auto groups = QVector<int>();
|
||||
auto maxMatchedDigits = size_t(0);
|
||||
|
@ -408,7 +427,7 @@ FormatResult CountriesInstance::format(FormatArgs args) {
|
|||
|
||||
if (!args.skipCode) {
|
||||
if (args.onlyGroups) {
|
||||
groups.push_front(bestCallingCodePtr->callingCode.size());
|
||||
groups.push_front(codeSize);
|
||||
} else {
|
||||
formattedResult = '+'
|
||||
+ bestCallingCodePtr->callingCode
|
||||
|
|
|
@ -34,6 +34,7 @@ struct FormatArgs {
|
|||
QString phone;
|
||||
bool onlyGroups = false;
|
||||
bool skipCode = false;
|
||||
bool incomplete = false;
|
||||
};
|
||||
|
||||
class CountriesInstance final {
|
||||
|
|
|
@ -9,7 +9,6 @@ https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
|
|||
|
||||
#include "lang/lang_keys.h"
|
||||
#include "countries/countries_instance.h" // Countries::ValidPhoneCode
|
||||
#include "numbers.h"
|
||||
|
||||
#include <QtCore/QRegularExpression>
|
||||
|
||||
|
@ -205,7 +204,11 @@ void PhonePartInput::addedToNumber(const QString &added) {
|
|||
}
|
||||
|
||||
void PhonePartInput::chooseCode(const QString &code) {
|
||||
_pattern = phoneNumberParse(code);
|
||||
_pattern = Countries::Instance().format({
|
||||
.phone = code,
|
||||
.onlyGroups = true,
|
||||
.incomplete = true,
|
||||
}).groups;
|
||||
if (!_pattern.isEmpty() && _pattern.at(0) == code.size()) {
|
||||
_pattern.pop_front();
|
||||
} else {
|
||||
|
@ -284,7 +287,10 @@ void UsernameInput::correctValue(
|
|||
}
|
||||
|
||||
QString ExtractPhonePrefix(const QString &phone) {
|
||||
const auto pattern = phoneNumberParse(phone);
|
||||
const auto pattern = Countries::Instance().format({
|
||||
.phone = phone,
|
||||
.onlyGroups = true,
|
||||
}).groups;
|
||||
if (!pattern.isEmpty()) {
|
||||
return phone.mid(0, pattern[0]);
|
||||
}
|
||||
|
@ -343,7 +349,11 @@ void PhoneInput::correctValue(
|
|||
int &nowCursor) {
|
||||
auto digits = now;
|
||||
digits.replace(QRegularExpression("[^\\d]"), QString());
|
||||
_pattern = phoneNumberParse(digits);
|
||||
_pattern = Countries::Instance().format({
|
||||
.phone = digits,
|
||||
.onlyGroups = true,
|
||||
.incomplete = true,
|
||||
}).groups;
|
||||
|
||||
QString newPlaceholder;
|
||||
if (_pattern.isEmpty()) {
|
||||
|
|
Loading…
Add table
Reference in a new issue