Add support for opening usercards by ID (#4934)

Co-authored-by: nerix <nerixdev@outlook.de>
This commit is contained in:
Mm2PL 2023-11-06 20:42:24 +01:00 committed by GitHub
parent 5209e47df1
commit f943f70634
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 38 additions and 5 deletions

View file

@ -7,6 +7,7 @@
- Minor: The account switcher is now styled to match your theme. (#4817) - Minor: The account switcher is now styled to match your theme. (#4817)
- Minor: Add an invisible resize handle to the bottom of frameless user info popups and reply thread popups. (#4795) - Minor: Add an invisible resize handle to the bottom of frameless user info popups and reply thread popups. (#4795)
- Minor: The installer now checks for the VC Runtime version and shows more info when it's outdated. (#4847) - Minor: The installer now checks for the VC Runtime version and shows more info when it's outdated. (#4847)
- Minor: The `/usercard` command now accepts user ids. (#4934)
- Minor: Add menu actions to reply directly to a message or the original thread root. (#4923) - Minor: Add menu actions to reply directly to a message or the original thread root. (#4923)
- Minor: The `/reply` command now replies to the latest message of the user. (#4919) - Minor: The `/reply` command now replies to the latest message of the user. (#4919)
- Bugfix: Fixed an issue where certain emojis did not send to Twitch chat correctly. (#4840) - Bugfix: Fixed an issue where certain emojis did not send to Twitch chat correctly. (#4840)

View file

@ -856,7 +856,8 @@ void CommandController::initialize(Settings &, Paths &paths)
if (words.size() < 2) if (words.size() < 2)
{ {
channel->addMessage( channel->addMessage(
makeSystemMessage("Usage: /usercard <user> [channel]")); makeSystemMessage("Usage: /usercard <username> [channel] or "
"/usercard id:<id> [channel]"));
return ""; return "";
} }

View file

@ -700,8 +700,19 @@ void UserInfoPopup::setData(const QString &name, const ChannelPtr &channel)
void UserInfoPopup::setData(const QString &name, void UserInfoPopup::setData(const QString &name,
const ChannelPtr &contextChannel, const ChannelPtr &contextChannel,
const ChannelPtr &openingChannel) const ChannelPtr &openingChannel)
{
const QStringView idPrefix = u"id:";
bool isId = name.startsWith(idPrefix);
if (isId)
{
this->userId_ = name.mid(idPrefix.size());
this->userName_ = "";
}
else
{ {
this->userName_ = name; this->userName_ = name;
}
this->channel_ = openingChannel; this->channel_ = openingChannel;
if (!contextChannel->isEmpty()) if (!contextChannel->isEmpty())
@ -723,8 +734,12 @@ void UserInfoPopup::setData(const QString &name,
this->userStateChanged_.invoke(); this->userStateChanged_.invoke();
if (!isId)
{
this->updateLatestMessages(); this->updateLatestMessages();
} }
// If we're opening by ID, this will be called as soon as we get the information from twitch
}
void UserInfoPopup::updateLatestMessages() void UserInfoPopup::updateLatestMessages()
{ {
@ -792,6 +807,14 @@ void UserInfoPopup::updateUserData()
return; return;
} }
// Correct for when being opened with ID
if (this->userName_.isEmpty())
{
this->userName_ = user.login;
// Ensure recent messages are shown
this->updateLatestMessages();
}
this->userId_ = user.id; this->userId_ = user.id;
this->avatarUrl_ = user.profileImageUrl; this->avatarUrl_ = user.profileImageUrl;
@ -909,8 +932,16 @@ void UserInfoPopup::updateUserData()
[] {}); [] {});
}; };
if (!this->userId_.isEmpty())
{
getHelix()->getUserById(this->userId_, onUserFetched,
onUserFetchFailed);
}
else
{
getHelix()->getUserByName(this->userName_, onUserFetched, getHelix()->getUserByName(this->userName_, onUserFetched,
onUserFetchFailed); onUserFetchFailed);
}
this->ui_.block->setEnabled(false); this->ui_.block->setEnabled(false);
this->ui_.ignoreHighlights->setEnabled(false); this->ui_.ignoreHighlights->setEnabled(false);