From 446a3193b1f2932ed14a16216bcf65dc30889612 Mon Sep 17 00:00:00 2001 From: Cho Date: Thu, 24 Apr 2014 23:43:54 +0100 Subject: Refactored to share code between experience search floater and panel for ACME-1420 --- indra/newview/llfloaterexperiencepicker.cpp | 372 +-------------------- indra/newview/llfloaterexperiencepicker.h | 35 +- indra/newview/llfloaterregioninfo.cpp | 8 +- indra/newview/llpanelexperiencepicker.cpp | 60 +++- indra/newview/llpanelexperiencepicker.h | 5 +- .../default/xui/en/floater_experience_search.xml | 156 +-------- indra/newview/skins/default/xui/en/menu_viewer.xml | 7 - .../default/xui/en/panel_experience_search.xml | 30 +- 8 files changed, 100 insertions(+), 573 deletions(-) diff --git a/indra/newview/llfloaterexperiencepicker.cpp b/indra/newview/llfloaterexperiencepicker.cpp index f68bf7f9a6..4a484463e8 100644 --- a/indra/newview/llfloaterexperiencepicker.cpp +++ b/indra/newview/llfloaterexperiencepicker.cpp @@ -42,46 +42,8 @@ #include "llcombobox.h" #include "llviewercontrol.h" #include "lldraghandle.h" +#include "llpanelexperiencepicker.h" -#define BTN_FIND "find" -#define BTN_OK "ok_btn" -#define BTN_CANCEL "cancel_btn" -#define BTN_PROFILE "profile_btn" -#define TEXT_EDIT "edit" -#define TEXT_MATURITY "maturity" -#define LIST_RESULTS "search_results" -#define PANEL_SEARCH "search_panel" - -const static std::string columnSpace = " "; - -class LLExperiencePickerResponder : public LLHTTPClient::Responder -{ -public: - LLUUID mQueryID; - LLHandle mParent; - - LLExperiencePickerResponder(const LLUUID& id, const LLHandle& parent) : mQueryID(id), mParent(parent) { } - - void completed(U32 status, const std::string& reason, const LLSD& content) - { - if (isGoodStatus(status)) - { - if(mParent.isDead()) - return; - - LLFloaterExperiencePicker* floater =mParent.get(); - if (floater) - { - floater->processResponse(mQueryID, content); - } - } - else - { - llwarns << "avatar picker failed [status:" << status << "]: " << content << llendl; - - } - } -}; LLFloaterExperiencePicker* LLFloaterExperiencePicker::show( select_callback_t callback, const LLUUID& key, BOOL allow_multiple, BOOL closeOnSelect, LLView * frustumOrigin ) { LLFloaterExperiencePicker* floater = @@ -94,7 +56,7 @@ LLFloaterExperiencePicker* LLFloaterExperiencePicker::show( select_callback_t ca floater->mSelectionCallback = callback; floater->mCloseOnSelect = closeOnSelect; - floater->setAllowMultiple(allow_multiple); + floater->mAllowMultiple = allow_multiple; if(frustumOrigin) { @@ -104,7 +66,6 @@ LLFloaterExperiencePicker* LLFloaterExperiencePicker::show( select_callback_t ca return floater; } - void LLFloaterExperiencePicker::drawFrustum() { if(mFrustumOrigin.get()) @@ -170,13 +131,12 @@ void LLFloaterExperiencePicker::draw() LLFloaterExperiencePicker::LLFloaterExperiencePicker( const LLSD& key ) :LLFloater(key) - ,mContextConeOpacity (0.f) + ,mSearchPanel(NULL) + ,mContextConeOpacity(0.f) ,mContextConeInAlpha(0.f) ,mContextConeOutAlpha(0.f) ,mContextConeFadeTime(0.f) { - setDefaultFilters(); - mContextConeInAlpha = gSavedSettings.getF32("ContextConeInAlpha"); mContextConeOutAlpha = gSavedSettings.getF32("ContextConeOutAlpha"); mContextConeFadeTime = gSavedSettings.getF32("ContextConeFadeTime"); @@ -187,324 +147,14 @@ LLFloaterExperiencePicker::~LLFloaterExperiencePicker() gFocusMgr.releaseFocusIfNeeded( this ); } - - BOOL LLFloaterExperiencePicker::postBuild() { - getChild(TEXT_EDIT)->setKeystrokeCallback( boost::bind(&LLFloaterExperiencePicker::editKeystroke, this, _1, _2),NULL); - - childSetAction(BTN_FIND, boost::bind(&LLFloaterExperiencePicker::onBtnFind, this)); - getChildView(BTN_FIND)->setEnabled(FALSE); - - LLScrollListCtrl* searchresults = getChild(LIST_RESULTS); - searchresults->setDoubleClickCallback( boost::bind(&LLFloaterExperiencePicker::onBtnSelect, this)); - searchresults->setCommitCallback(boost::bind(&LLFloaterExperiencePicker::onList, this)); - getChildView(LIST_RESULTS)->setEnabled(FALSE); - getChild(LIST_RESULTS)->setCommentText(getString("no_results")); - - childSetAction(BTN_OK, boost::bind(&LLFloaterExperiencePicker::onBtnSelect, this)); - getChildView(BTN_OK)->setEnabled(FALSE); - childSetAction(BTN_CANCEL, boost::bind(&LLFloaterExperiencePicker::onBtnClose, this)); - childSetAction(BTN_PROFILE, boost::bind(&LLFloaterExperiencePicker::onBtnProfile, this)); - getChildView(BTN_PROFILE)->setEnabled(FALSE); - - getChild(TEXT_MATURITY)->setCurrentByIndex(2); - getChild(TEXT_MATURITY)->setCommitCallback(boost::bind(&LLFloaterExperiencePicker::onMaturity, this)); - getChild(TEXT_EDIT)->setFocus(TRUE); - - LLPanel* search_panel = getChild(PANEL_SEARCH); - if (search_panel) - { - // Start searching when Return is pressed in the line editor. - search_panel->setDefaultBtn(BTN_FIND); - } - return TRUE; -} - -void LLFloaterExperiencePicker::editKeystroke( class LLLineEditor* caller, void* user_data ) -{ - getChildView(BTN_FIND)->setEnabled(caller->getText().size() > 0); -} - -void LLFloaterExperiencePicker::onBtnFind() -{ - find(); -} - -void LLFloaterExperiencePicker::onBtnSelect() -{ - if(!isSelectButtonEnabled()) - { - return; - } - - if(mSelectionCallback) - { - const LLScrollListCtrl* results = getChild(LIST_RESULTS); - uuid_vec_t experience_ids; - - getSelectedExperienceIds(results, experience_ids); - mSelectionCallback(experience_ids); - getChild(LIST_RESULTS)->deselectAllItems(TRUE); - if(mCloseOnSelect) - { - mCloseOnSelect = FALSE; - closeFloater(); - } - } - else - { - onBtnProfile(); - } -} - -void LLFloaterExperiencePicker::onList() -{ - bool enabled = isSelectButtonEnabled(); - getChildView(BTN_OK)->setEnabled(enabled); - - enabled = enabled && getChild(LIST_RESULTS)->getNumSelected() == 1; - getChildView(BTN_PROFILE)->setEnabled(enabled); -} - - -void LLFloaterExperiencePicker::onBtnClose() -{ - closeFloater(); -} - - -void LLFloaterExperiencePicker::find() -{ - std::string text = getChild(TEXT_EDIT)->getValue().asString(); - mQueryID.generate(); - std::string url; - url.reserve(128+text.size()); - - LLViewerRegion* region = gAgent.getRegion(); - url = region->getCapability("FindExperienceByName"); - if (!url.empty()) - { - url+="?query="; - url+=LLURI::escape(text); - LLHTTPClient::get(url, new LLExperiencePickerResponder(mQueryID, getDerivedHandle())); - - } - - - getChild(LIST_RESULTS)->deleteAllItems(); - getChild(LIST_RESULTS)->setCommentText(getString("searching")); - - getChildView(BTN_OK)->setEnabled(FALSE); - getChildView(BTN_PROFILE)->setEnabled(FALSE); -} - - -bool LLFloaterExperiencePicker::isSelectButtonEnabled() -{ - LLScrollListCtrl* list=getChild(LIST_RESULTS); - return list->getFirstSelectedIndex() >=0; -} - -void LLFloaterExperiencePicker::getSelectedExperienceIds( const LLScrollListCtrl* results, uuid_vec_t &experience_ids ) -{ - std::vector items = results->getAllSelected(); - for(std::vector::iterator it = items.begin(); it != items.end(); ++it) - { - LLScrollListItem* item = *it; - if (item->getUUID().notNull()) - { - experience_ids.push_back(item->getUUID()); - } - } -} - -void LLFloaterExperiencePicker::setAllowMultiple( bool allow_multiple ) -{ - getChild(LIST_RESULTS)->setAllowMultipleSelection(allow_multiple); -} - - -void name_callback(const LLHandle& floater, const LLUUID& experience_id, const LLUUID& agent_id, const LLAvatarName& av_name) -{ - if(floater.isDead()) - return; - LLFloaterExperiencePicker* picker = floater.get(); - LLScrollListCtrl* search_results = picker->getChild(LIST_RESULTS); - - LLScrollListItem* item = search_results->getItem(experience_id); - if(!item) - return; - - item->getColumn(2)->setValue(columnSpace+av_name.getDisplayName()); - -} - -void LLFloaterExperiencePicker::processResponse( const LLUUID& query_id, const LLSD& content ) -{ - if(query_id != mQueryID) - { - return; - } - - mResponse = content; - - const LLSD& experiences=mResponse["experience_keys"]; - LLSD::array_const_iterator it = experiences.beginArray(); - for ( ; it != experiences.endArray(); ++it) - { - LLExperienceCache::insert(*it); - } - - filterContent(); - -} - -void LLFloaterExperiencePicker::onBtnProfile() -{ - LLScrollListItem* item = getChild(LIST_RESULTS)->getFirstSelected(); - if(item) - { - LLFloaterReg::showInstance("experience_profile", item->getUUID(), true); - } -} - -std::string LLFloaterExperiencePicker::getMaturityString(int maturity) -{ - if(maturity <= SIM_ACCESS_PG) - { - return getString("maturity_icon_general"); - } - else if(maturity <= SIM_ACCESS_MATURE) - { - return getString("maturity_icon_moderate"); - } - return getString("maturity_icon_adult"); -} - -void LLFloaterExperiencePicker::filterContent() -{ - LLScrollListCtrl* search_results = getChild(LIST_RESULTS); - - const LLSD& experiences=mResponse["experience_keys"]; - - search_results->deleteAllItems(); - - LLSD item; - LLSD::array_const_iterator it = experiences.beginArray(); - for ( ; it != experiences.endArray(); ++it) - { - const LLSD& experience = *it; - - if(isExperienceHidden(experience)) - continue; - - item["id"]=experience[LLExperienceCache::EXPERIENCE_ID]; - LLSD& columns = item["columns"]; - columns[0]["column"] = "maturity"; - columns[0]["value"] = getMaturityString(experience[LLExperienceCache::MATURITY].asInteger()); - columns[0]["type"]="icon"; - columns[0]["halign"]="right"; - columns[1]["column"] = "experience_name"; - columns[1]["value"] = columnSpace+experience[LLExperienceCache::NAME].asString(); - columns[2]["column"] = "owner"; - columns[2]["value"] = columnSpace+getString("loading"); - search_results->addElement(item); - LLAvatarNameCache::get(experience[LLExperienceCache::AGENT_ID], boost::bind(name_callback, getDerivedHandle(), experience[LLExperienceCache::EXPERIENCE_ID], _1, _2)); - } - - if (search_results->isEmpty()) - { - LLStringUtil::format_map_t map; - std::string search_text = childGetText(TEXT_EDIT); - map["[TEXT]"] = search_text; - if (search_text.empty()) - { - getChild(LIST_RESULTS)->setCommentText(getString("no_results")); - } - else - { - getChild(LIST_RESULTS)->setCommentText(getString("not_found", map)); - } - search_results->setEnabled(false); - getChildView(BTN_OK)->setEnabled(false); - getChildView(BTN_PROFILE)->setEnabled(false); - } - else - { - getChildView(BTN_OK)->setEnabled(true); - search_results->setEnabled(true); - search_results->sortByColumnIndex(1, TRUE); - std::string text = getChild(TEXT_EDIT)->getValue().asString(); - if (!search_results->selectItemByLabel(text, TRUE, 1)) - { - search_results->selectFirstItem(); - } - onList(); - search_results->setFocus(TRUE); - } -} - -void LLFloaterExperiencePicker::onMaturity() -{ - if(mResponse.has("experience_keys") && mResponse["experience_keys"].beginArray() != mResponse["experience_keys"].endArray()) - { - filterContent(); - } -} - -bool LLFloaterExperiencePicker::isExperienceHidden( const LLSD& experience) const -{ - bool hide=false; - filter_list::const_iterator it = mFilters.begin(); - for(/**/;it != mFilters.end(); ++it) - { - if((*it)(experience)){ - return true; - } - } - - return hide; -} - -bool LLFloaterExperiencePicker::FilterOverRating( const LLSD& experience ) -{ - int maturity = getChild(TEXT_MATURITY)->getSelectedValue().asInteger(); - return experience[LLExperienceCache::MATURITY].asInteger() > maturity; -} + mSearchPanel = static_cast(getChild("panel_experience_search")); + + mSearchPanel->mSelectionCallback = mSelectionCallback; + mSearchPanel->mCloseOnSelect = mCloseOnSelect; + mSearchPanel->setAllowMultiple(mAllowMultiple); + mSearchPanel->addFilters(mFilters.begin(), mFilters.end()); -bool LLFloaterExperiencePicker::FilterWithProperty( const LLSD& experience, S32 prop) -{ - return (experience[LLExperienceCache::PROPERTIES].asInteger() & prop) != 0; + return LLFloater::postBuild(); } - -bool LLFloaterExperiencePicker::FilterWithoutProperty( const LLSD& experience, S32 prop ) -{ - return (experience[LLExperienceCache::PROPERTIES].asInteger() & prop) == 0; -} - -void LLFloaterExperiencePicker::setDefaultFilters() -{ - mFilters.clear(); - addFilter(boost::bind(&LLFloaterExperiencePicker::FilterOverRating, this, _1)); -} - - - - - - - - - - - - - - - - - - - - diff --git a/indra/newview/llfloaterexperiencepicker.h b/indra/newview/llfloaterexperiencepicker.h index ea0240d2ac..22bfb64ba7 100644 --- a/indra/newview/llfloaterexperiencepicker.h +++ b/indra/newview/llfloaterexperiencepicker.h @@ -31,6 +31,7 @@ class LLScrollListCtrl; class LLLineEditor; +class LLPanelExperiencePicker; class LLFloaterExperiencePicker : public LLFloater @@ -38,7 +39,6 @@ class LLFloaterExperiencePicker : public LLFloater public: friend class LLExperiencePickerResponder; - // The callback function will be called with an avatar name and UUID. typedef boost::function select_callback_t; // filter function for experiences, return true if the experience should be hidden. typedef boost::function filter_function; @@ -50,47 +50,20 @@ public: virtual ~LLFloaterExperiencePicker(); BOOL postBuild(); - - void addFilter(filter_function func){mFilters.push_back(func);} + template void addFilters(IT begin, IT end){mFilters.insert(mFilters.end(), begin, end);} - void setDefaultFilters(); - - static bool FilterWithProperty(const LLSD& experience, S32 prop); - static bool FilterWithoutProperty(const LLSD& experience, S32 prop); - bool FilterOverRating(const LLSD& experience); virtual void draw(); private: - void editKeystroke(LLLineEditor* caller, void* user_data); - - void onBtnFind(); - void onBtnSelect(); - void onBtnProfile(); - void onBtnClose(); - void onList(); - void onMaturity(); - - void getSelectedExperienceIds( const LLScrollListCtrl* results, uuid_vec_t &experience_ids ); - void setAllowMultiple(bool allow_multiple); - - - void find(); - bool isSelectButtonEnabled(); - void processResponse( const LLUUID& query_id, const LLSD& content ); - - void filterContent(); - bool isExperienceHidden(const LLSD& experience) const ; - std::string getMaturityString(int maturity); + LLPanelExperiencePicker* mSearchPanel; select_callback_t mSelectionCallback; filter_list mFilters; - LLUUID mQueryID; - LLSD mResponse; + bool mAllowMultiple; bool mCloseOnSelect; - void drawFrustum(); LLHandle mFrustumOrigin; F32 mContextConeOpacity; diff --git a/indra/newview/llfloaterregioninfo.cpp b/indra/newview/llfloaterregioninfo.cpp index 2522b7bf18..6d8f8f5587 100755 --- a/indra/newview/llfloaterregioninfo.cpp +++ b/indra/newview/llfloaterregioninfo.cpp @@ -94,7 +94,7 @@ #include "llfloaterregionrestarting.h" #include "llpanelexperiencelisteditor.h" #include -#include "llfloaterexperiencepicker.h" +#include "llpanelexperiencepicker.h" #include "llexperiencecache.h" #include "llpanelexperiences.h" @@ -3634,14 +3634,14 @@ bool LLPanelRegionExperiences::refreshFromRegion(LLViewerRegion* region) mAllowed->loading(); mAllowed->setReadonly(!allow_modify); // remove grid-wide experiences - mAllowed->addFilter(boost::bind(LLFloaterExperiencePicker::FilterWithProperty, _1, LLExperienceCache::PROPERTY_GRID)); + mAllowed->addFilter(boost::bind(LLPanelExperiencePicker::FilterWithProperty, _1, LLExperienceCache::PROPERTY_GRID)); mBlocked->loading(); mBlocked->setReadonly(!allow_modify); // only grid-wide experiences - mBlocked->addFilter(boost::bind(LLFloaterExperiencePicker::FilterWithoutProperty, _1, LLExperienceCache::PROPERTY_GRID)); + mBlocked->addFilter(boost::bind(LLPanelExperiencePicker::FilterWithoutProperty, _1, LLExperienceCache::PROPERTY_GRID)); // but not privileged ones - mBlocked->addFilter(boost::bind(LLFloaterExperiencePicker::FilterWithProperty, _1, LLExperienceCache::PROPERTY_PRIVILEGED)); + mBlocked->addFilter(boost::bind(LLPanelExperiencePicker::FilterWithProperty, _1, LLExperienceCache::PROPERTY_PRIVILEGED)); mTrusted->loading(); mTrusted->setReadonly(!allow_modify); diff --git a/indra/newview/llpanelexperiencepicker.cpp b/indra/newview/llpanelexperiencepicker.cpp index 4e2ae585cd..8da41b59dd 100644 --- a/indra/newview/llpanelexperiencepicker.cpp +++ b/indra/newview/llpanelexperiencepicker.cpp @@ -38,12 +38,13 @@ #include "llexperiencecache.h" #include "llslurl.h" #include "llavatarnamecache.h" -#include "llfloaterexperienceprofile.h" #include "llcombobox.h" #include "llviewercontrol.h" -#include "lldraghandle.h" +#include "llfloater.h" #define BTN_FIND "find" +#define BTN_OK "ok_btn" +#define BTN_CANCEL "cancel_btn" #define BTN_PROFILE "profile_btn" #define TEXT_EDIT "edit" #define TEXT_MATURITY "maturity" @@ -52,6 +53,8 @@ const static std::string columnSpace = " "; +static LLPanelInjector t_panel_status("llpanelexperiencepicker"); + class LLExperienceSearchResponder : public LLHTTPClient::Responder { public: @@ -75,7 +78,7 @@ public: } else { - llwarns << "avatar picker failed [status:" << status << "]: " << content << llendl; + llwarns << "experience picker failed [status:" << status << "]: " << content << llendl; } } @@ -90,7 +93,6 @@ LLPanelExperiencePicker::LLPanelExperiencePicker() LLPanelExperiencePicker::~LLPanelExperiencePicker() { - gFocusMgr.releaseFocusIfNeeded( this ); } BOOL LLPanelExperiencePicker::postBuild() @@ -101,11 +103,14 @@ BOOL LLPanelExperiencePicker::postBuild() getChildView(BTN_FIND)->setEnabled(FALSE); LLScrollListCtrl* searchresults = getChild(LIST_RESULTS); - searchresults->setDoubleClickCallback( boost::bind(&LLPanelExperiencePicker::onBtnProfile, this)); + searchresults->setDoubleClickCallback( boost::bind(&LLPanelExperiencePicker::onBtnSelect, this)); searchresults->setCommitCallback(boost::bind(&LLPanelExperiencePicker::onList, this)); getChildView(LIST_RESULTS)->setEnabled(FALSE); getChild(LIST_RESULTS)->setCommentText(getString("no_results")); + childSetAction(BTN_OK, boost::bind(&LLPanelExperiencePicker::onBtnSelect, this)); + getChildView(BTN_OK)->setEnabled(FALSE); + childSetAction(BTN_CANCEL, boost::bind(&LLPanelExperiencePicker::onBtnClose, this)); childSetAction(BTN_PROFILE, boost::bind(&LLPanelExperiencePicker::onBtnProfile, this)); getChildView(BTN_PROFILE)->setEnabled(FALSE); @@ -135,6 +140,7 @@ void LLPanelExperiencePicker::onBtnFind() void LLPanelExperiencePicker::onList() { bool enabled = isSelectButtonEnabled(); + getChildView(BTN_OK)->setEnabled(enabled); enabled = enabled && getChild(LIST_RESULTS)->getNumSelected() == 1; getChildView(BTN_PROFILE)->setEnabled(enabled); @@ -157,10 +163,10 @@ void LLPanelExperiencePicker::find() } - getChild(LIST_RESULTS)->deleteAllItems(); getChild(LIST_RESULTS)->setCommentText(getString("searching")); - + + getChildView(BTN_OK)->setEnabled(FALSE); getChildView(BTN_PROFILE)->setEnabled(FALSE); } @@ -225,6 +231,42 @@ void LLPanelExperiencePicker::processResponse( const LLUUID& query_id, const LLS } +void LLPanelExperiencePicker::onBtnSelect() +{ + if(!isSelectButtonEnabled()) + { + return; + } + + if(mSelectionCallback) + { + const LLScrollListCtrl* results = getChild(LIST_RESULTS); + uuid_vec_t experience_ids; + + getSelectedExperienceIds(results, experience_ids); + mSelectionCallback(experience_ids); + getChild(LIST_RESULTS)->deselectAllItems(TRUE); + if(mCloseOnSelect) + { + mCloseOnSelect = FALSE; + onBtnClose(); + } + } + else + { + onBtnProfile(); + } +} + +void LLPanelExperiencePicker::onBtnClose() +{ + LLFloater* floater = getParentByType(); + if (floater) + { + floater->closeFloater(); + } +} + void LLPanelExperiencePicker::onBtnProfile() { LLScrollListItem* item = getChild(LIST_RESULTS)->getFirstSelected(); @@ -277,7 +319,7 @@ void LLPanelExperiencePicker::filterContent() search_results->addElement(item); LLAvatarNameCache::get(experience[LLExperienceCache::AGENT_ID], boost::bind(name_callback, getDerivedHandle(), experience[LLExperienceCache::EXPERIENCE_ID], _1, _2)); } - + if (search_results->isEmpty()) { LLStringUtil::format_map_t map; @@ -292,10 +334,12 @@ void LLPanelExperiencePicker::filterContent() getChild(LIST_RESULTS)->setCommentText(getString("not_found", map)); } search_results->setEnabled(false); + getChildView(BTN_OK)->setEnabled(false); getChildView(BTN_PROFILE)->setEnabled(false); } else { + getChildView(BTN_OK)->setEnabled(true); search_results->setEnabled(true); search_results->sortByColumnIndex(1, TRUE); std::string text = getChild(TEXT_EDIT)->getValue().asString(); diff --git a/indra/newview/llpanelexperiencepicker.h b/indra/newview/llpanelexperiencepicker.h index 166639a14e..af0a30ceba 100644 --- a/indra/newview/llpanelexperiencepicker.h +++ b/indra/newview/llpanelexperiencepicker.h @@ -37,8 +37,8 @@ class LLPanelExperiencePicker : public LLPanel { public: friend class LLExperienceSearchResponder; + friend class LLFloaterExperiencePicker; - // The callback function will be called with an avatar name and UUID. typedef boost::function select_callback_t; // filter function for experiences, return true if the experience should be hidden. typedef boost::function filter_function; @@ -62,6 +62,8 @@ private: void editKeystroke(LLLineEditor* caller, void* user_data); void onBtnFind(); + void onBtnSelect(); + void onBtnClose(); void onBtnProfile(); void onList(); void onMaturity(); @@ -83,6 +85,7 @@ private: filter_list mFilters; LLUUID mQueryID; LLSD mResponse; + bool mCloseOnSelect; }; #endif // LL_LLPANELEXPERIENCEPICKER_H diff --git a/indra/newview/skins/default/xui/en/floater_experience_search.xml b/indra/newview/skins/default/xui/en/floater_experience_search.xml index 8b44dada40..7d7e3ba95a 100644 --- a/indra/newview/skins/default/xui/en/floater_experience_search.xml +++ b/indra/newview/skins/default/xui/en/floater_experience_search.xml @@ -12,159 +12,9 @@ title="CHOOSE EXPERIENCE" width="350"> - - '[TEXT]' not found - - - No results - - - Searching... - - - Loading... - - - "Parcel_PG_Light" - - - "Parcel_M_Light" - - - "Parcel_R_Light" - - - Enter part of the name: - - -