diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/llpanelavatar.cpp | 36 |
1 files changed, 28 insertions, 8 deletions
diff --git a/linden/indra/newview/llpanelavatar.cpp b/linden/indra/newview/llpanelavatar.cpp index 0180bb3..b79993f 100644 --- a/linden/indra/newview/llpanelavatar.cpp +++ b/linden/indra/newview/llpanelavatar.cpp | |||
@@ -91,6 +91,7 @@ BOOL LLPanelAvatar::sAllowFirstLife = FALSE; | |||
91 | // RN: move these to lldbstrings.h | 91 | // RN: move these to lldbstrings.h |
92 | static const S32 DB_USER_FAVORITES_STR_LEN = 254; | 92 | static const S32 DB_USER_FAVORITES_STR_LEN = 254; |
93 | 93 | ||
94 | const char LOADING_MSG[] = "Loading..."; | ||
94 | static const char IM_DISABLED_TOOLTIP[] = "Instant Message (IM).\nDisabled because you do not have their card."; | 95 | static const char IM_DISABLED_TOOLTIP[] = "Instant Message (IM).\nDisabled because you do not have their card."; |
95 | static const char IM_ENABLED_TOOLTIP[] = "Instant Message (IM)"; | 96 | static const char IM_ENABLED_TOOLTIP[] = "Instant Message (IM)"; |
96 | static const S32 LEFT = HPAD; | 97 | static const S32 LEFT = HPAD; |
@@ -830,7 +831,7 @@ void LLPanelAvatarNotes::refresh() | |||
830 | 831 | ||
831 | void LLPanelAvatarNotes::clearControls() | 832 | void LLPanelAvatarNotes::clearControls() |
832 | { | 833 | { |
833 | childSetText("notes edit", "Loading..."); | 834 | childSetText("notes edit", LOADING_MSG); |
834 | childSetEnabled("notes edit", false); | 835 | childSetEnabled("notes edit", false); |
835 | } | 836 | } |
836 | 837 | ||
@@ -1271,6 +1272,8 @@ LLPanelAvatar::LLPanelAvatar( | |||
1271 | mAvatarID( LLUUID::null ), // mAvatarID is set with 'setAvatar' or 'setAvatarID' | 1272 | mAvatarID( LLUUID::null ), // mAvatarID is set with 'setAvatar' or 'setAvatarID' |
1272 | mHaveProperties(FALSE), | 1273 | mHaveProperties(FALSE), |
1273 | mHaveStatistics(FALSE), | 1274 | mHaveStatistics(FALSE), |
1275 | mHaveNotes(false), | ||
1276 | mLastNotes(), | ||
1274 | mAllowEdit(allow_edit) | 1277 | mAllowEdit(allow_edit) |
1275 | { | 1278 | { |
1276 | 1279 | ||
@@ -1415,6 +1418,7 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, | |||
1415 | setOnlineStatus(online_status); | 1418 | setOnlineStatus(online_status); |
1416 | 1419 | ||
1417 | BOOL own_avatar = (mAvatarID == gAgent.getID() ); | 1420 | BOOL own_avatar = (mAvatarID == gAgent.getID() ); |
1421 | BOOL avatar_is_friend = LLAvatarTracker::instance().getBuddyInfo(mAvatarID) != NULL; | ||
1418 | 1422 | ||
1419 | mPanelSecondLife->enableControls(own_avatar && mAllowEdit); | 1423 | mPanelSecondLife->enableControls(own_avatar && mAllowEdit); |
1420 | mPanelWeb->enableControls(own_avatar && mAllowEdit); | 1424 | mPanelWeb->enableControls(own_avatar && mAllowEdit); |
@@ -1460,6 +1464,8 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, | |||
1460 | 1464 | ||
1461 | mPanelNotes->clearControls(); | 1465 | mPanelNotes->clearControls(); |
1462 | mPanelNotes->setDataRequested(false); | 1466 | mPanelNotes->setDataRequested(false); |
1467 | mHaveNotes = false; | ||
1468 | mLastNotes.clear(); | ||
1463 | 1469 | ||
1464 | // Request just the first two pages of data. The picks, | 1470 | // Request just the first two pages of data. The picks, |
1465 | // classifieds, and notes will be requested when that panel | 1471 | // classifieds, and notes will be requested when that panel |
@@ -1471,8 +1477,8 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, | |||
1471 | if (mAllowEdit) | 1477 | if (mAllowEdit) |
1472 | { | 1478 | { |
1473 | // OK button disabled until properties data arrives | 1479 | // OK button disabled until properties data arrives |
1474 | childSetVisible("OK",TRUE); | 1480 | childSetVisible("OK", true); |
1475 | childSetEnabled("OK",TRUE); | 1481 | childSetEnabled("OK", false); |
1476 | childSetVisible("Cancel",TRUE); | 1482 | childSetVisible("Cancel",TRUE); |
1477 | childSetEnabled("Cancel",TRUE); | 1483 | childSetEnabled("Cancel",TRUE); |
1478 | } | 1484 | } |
@@ -1530,7 +1536,7 @@ void LLPanelAvatar::setAvatarID(const LLUUID &avatar_id, const LLString &name, | |||
1530 | childSetToolTip("Show on Map",childGetValue("ShowOnMapFriendOnline").asString()); | 1536 | childSetToolTip("Show on Map",childGetValue("ShowOnMapFriendOnline").asString()); |
1531 | } | 1537 | } |
1532 | childSetVisible("Add Friend...", true); | 1538 | childSetVisible("Add Friend...", true); |
1533 | childSetEnabled("Add Friend...", true); | 1539 | childSetEnabled("Add Friend...", !avatar_is_friend); |
1534 | childSetVisible("Pay...",TRUE); | 1540 | childSetVisible("Pay...",TRUE); |
1535 | childSetEnabled("Pay...",FALSE); | 1541 | childSetEnabled("Pay...",FALSE); |
1536 | } | 1542 | } |
@@ -1604,12 +1610,12 @@ void LLPanelAvatar::resetGroupList() | |||
1604 | void LLPanelAvatar::onClickIM(void* userdata) | 1610 | void LLPanelAvatar::onClickIM(void* userdata) |
1605 | { | 1611 | { |
1606 | LLPanelAvatar* self = (LLPanelAvatar*) userdata; | 1612 | LLPanelAvatar* self = (LLPanelAvatar*) userdata; |
1607 | gIMView->setFloaterOpen(TRUE); | 1613 | gIMMgr->setFloaterOpen(TRUE); |
1608 | 1614 | ||
1609 | std::string name; | 1615 | std::string name; |
1610 | LLNameEditor* nameedit = LLViewerUICtrlFactory::getNameEditorByName(self->mPanelSecondLife, "name"); | 1616 | LLNameEditor* nameedit = LLViewerUICtrlFactory::getNameEditorByName(self->mPanelSecondLife, "name"); |
1611 | if (nameedit) name = nameedit->getText(); | 1617 | if (nameedit) name = nameedit->getText(); |
1612 | gIMView->addSession(name, IM_NOTHING_SPECIAL, self->mAvatarID); | 1618 | gIMMgr->addSession(name, IM_NOTHING_SPECIAL, self->mAvatarID); |
1613 | } | 1619 | } |
1614 | 1620 | ||
1615 | 1621 | ||
@@ -1639,7 +1645,7 @@ void LLPanelAvatar::onClickAddFriend(void* userdata) | |||
1639 | LLNameEditor* name_edit = LLViewerUICtrlFactory::getNameEditorByName(self->mPanelSecondLife, "name"); | 1645 | LLNameEditor* name_edit = LLViewerUICtrlFactory::getNameEditorByName(self->mPanelSecondLife, "name"); |
1640 | if (name_edit) | 1646 | if (name_edit) |
1641 | { | 1647 | { |
1642 | LLFloaterFriends::requestFriendshipDialog(self->getAvatarID(), | 1648 | LLPanelFriends::requestFriendshipDialog(self->getAvatarID(), |
1643 | name_edit->getText()); | 1649 | name_edit->getText()); |
1644 | } | 1650 | } |
1645 | } | 1651 | } |
@@ -1767,7 +1773,19 @@ void LLPanelAvatar::sendAvatarPropertiesRequest() | |||
1767 | void LLPanelAvatar::sendAvatarNotesUpdate() | 1773 | void LLPanelAvatar::sendAvatarNotesUpdate() |
1768 | { | 1774 | { |
1769 | std::string notes = mPanelNotes->childGetValue("notes edit").asString(); | 1775 | std::string notes = mPanelNotes->childGetValue("notes edit").asString(); |
1770 | 1776 | ||
1777 | if (!mHaveNotes | ||
1778 | && (notes.empty() || notes == LOADING_MSG)) | ||
1779 | { | ||
1780 | // no notes from server and no user updates | ||
1781 | return; | ||
1782 | } | ||
1783 | if (notes == mLastNotes) | ||
1784 | { | ||
1785 | // Avatar notes unchanged | ||
1786 | return; | ||
1787 | } | ||
1788 | |||
1771 | LLMessageSystem *msg = gMessageSystem; | 1789 | LLMessageSystem *msg = gMessageSystem; |
1772 | 1790 | ||
1773 | msg->newMessage("AvatarNotesUpdate"); | 1791 | msg->newMessage("AvatarNotesUpdate"); |
@@ -2175,6 +2193,8 @@ void LLPanelAvatar::processAvatarNotesReply(LLMessageSystem *msg, void**) | |||
2175 | msg->getString("Data", "Notes", DB_USER_NOTE_SIZE, text); | 2193 | msg->getString("Data", "Notes", DB_USER_NOTE_SIZE, text); |
2176 | self->childSetValue("notes edit", text); | 2194 | self->childSetValue("notes edit", text); |
2177 | self->childSetEnabled("notes edit", true); | 2195 | self->childSetEnabled("notes edit", true); |
2196 | self->mHaveNotes = true; | ||
2197 | self->mLastNotes = text; | ||
2178 | } | 2198 | } |
2179 | } | 2199 | } |
2180 | 2200 | ||