diff options
Diffstat (limited to 'indra/newview')
77 files changed, 2781 insertions, 1562 deletions
| diff --git a/indra/newview/CMakeLists.txt b/indra/newview/CMakeLists.txt index 4adef84cd3..e7458529be 100644 --- a/indra/newview/CMakeLists.txt +++ b/indra/newview/CMakeLists.txt @@ -297,8 +297,6 @@ set(viewer_SOURCE_FILES      llnotify.cpp      lloutputmonitorctrl.cpp      lloverlaybar.cpp -    llpanelappearance.cpp -    llpanelappearancetab.cpp      llpanelavatar.cpp      llpanelavatarrow.cpp      llpanelavatartag.cpp @@ -322,7 +320,6 @@ set(viewer_SOURCE_FILES      llpanellandmedia.cpp      llpanellogin.cpp      llpanellookinfo.cpp -    llpanellooks.cpp      llpanelmaininventory.cpp      llpanelmediasettingsgeneral.cpp      llpanelmediasettingspermissions.cpp @@ -330,6 +327,7 @@ set(viewer_SOURCE_FILES      llpanelmeprofile.cpp      llpanelobject.cpp      llpanelobjectinventory.cpp +    llpaneloutfitsinventory.cpp      llpanelpeople.cpp      llpanelpeoplemenus.cpp      llpanelpermissions.cpp @@ -370,6 +368,7 @@ set(viewer_SOURCE_FILES      llsearchcombobox.cpp      llsearchhistory.cpp      llselectmgr.cpp +    llsidepanelappearance.cpp      llsidepanelinventory.cpp      llsidepanelinventorysubpanel.cpp      llsidepaneliteminfo.cpp @@ -792,8 +791,6 @@ set(viewer_HEADER_FILES      llnotify.h      lloutputmonitorctrl.h      lloverlaybar.h -    llpanelappearance.h -    llpanelappearancetab.h      llpanelavatar.h      llpanelavatarrow.h      llpanelavatartag.h @@ -817,7 +814,6 @@ set(viewer_HEADER_FILES      llpanellandmedia.h      llpanellogin.h      llpanellookinfo.h -    llpanellooks.h      llpanelmaininventory.h      llpanelmediasettingsgeneral.h      llpanelmediasettingspermissions.h @@ -825,6 +821,7 @@ set(viewer_HEADER_FILES      llpanelmeprofile.h      llpanelobject.h      llpanelobjectinventory.h +    llpaneloutfitsinventory.h      llpanelpeople.h      llpanelpeoplemenus.h      llpanelpermissions.h @@ -867,6 +864,7 @@ set(viewer_HEADER_FILES      llsearchcombobox.h      llsearchhistory.h      llselectmgr.h +    llsidepanelappearance.h      llsidepanelinventory.h      llsidepanelinventorysubpanel.h      llsidepaneliteminfo.h diff --git a/indra/newview/app_settings/ignorable_dialogs.xml b/indra/newview/app_settings/ignorable_dialogs.xml index ab18febccc..669235af1b 100644 --- a/indra/newview/app_settings/ignorable_dialogs.xml +++ b/indra/newview/app_settings/ignorable_dialogs.xml @@ -1,291 +1,291 @@ -<?xml version="1.0" ?> -<llsd> -<map> -    <key>FirstAppearance</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstAppearance warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstAttach</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstAttach warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstBalanceDecrease</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstBalanceDecrease warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstBalanceIncrease</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstBalanceIncrease warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstBuild</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstBuild warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstDebugMenus</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstDebugMenus warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstFlexible</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstFlexible warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstGoTo</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstGoTo warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstInventory</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstInventory warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstLeftClickNoHit</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstLeftClickNoHit warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstMap</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstMap warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstMedia</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstMedia warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstOverrideKeys</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstOverrideKeys warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstSandbox</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstSandbox warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstSculptedPrim</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstSculptedPrim warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstSit</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstSit warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstStreamingMusic</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstStreamingMusic warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstStreamingVideo</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstStreamingVideo warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstTeleport</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstTeleport warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>FirstVoice</key> -    <map> -      <key>Comment</key> -      <string>Enables FirstVoice warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>AboutDirectX9</key> -    <map> -      <key>Comment</key> -      <string>Enables AboutDirectX9 warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>BrowserLaunch</key> -    <map> -      <key>Comment</key> -      <string>Enables BrowserLaunch warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>DeedObject</key> -    <map> -      <key>Comment</key> -      <string>Enables DeedObject warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -  <key>NewClassified</key> -    <map> -      <key>Comment</key> -      <string>Enables NewClassified warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>QuickTimeInstalled</key> -    <map> -      <key>Comment</key> -      <string>Enables QuickTimeInstalled warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -    <key>ReturnToOwner</key> -    <map> -      <key>Comment</key> -      <string>Enables ReturnToOwner warning dialog</string> -      <key>Persist</key> -      <integer>1</integer> -      <key>Type</key> -      <string>Boolean</string> -      <key>Value</key> -      <integer>1</integer> -    </map> -  </map> -</llsd> +<?xml version="1.0" ?>
 +<llsd>
 +<map>
 +    <key>FirstAppearance</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstAppearance warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstAttach</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstAttach warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstBalanceDecrease</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstBalanceDecrease warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstBalanceIncrease</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstBalanceIncrease warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstBuild</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstBuild warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstDebugMenus</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstDebugMenus warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstFlexible</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstFlexible warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstGoTo</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstGoTo warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstInventory</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstInventory warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstLeftClickNoHit</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstLeftClickNoHit warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstMap</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstMap warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstMedia</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstMedia warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstOverrideKeys</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstOverrideKeys warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstSandbox</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstSandbox warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstSculptedPrim</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstSculptedPrim warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstSit</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstSit warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstStreamingMusic</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstStreamingMusic warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstStreamingVideo</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstStreamingVideo warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstTeleport</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstTeleport warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>FirstVoice</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables FirstVoice warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>AboutDirectX9</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables AboutDirectX9 warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>BrowserLaunch</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables BrowserLaunch warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>DeedObject</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables DeedObject warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +  <key>NewClassified</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables NewClassified warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>QuickTimeInstalled</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables QuickTimeInstalled warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +    <key>ReturnToOwner</key>
 +    <map>
 +      <key>Comment</key>
 +      <string>Enables ReturnToOwner warning dialog</string>
 +      <key>Persist</key>
 +      <integer>1</integer>
 +      <key>Type</key>
 +      <string>Boolean</string>
 +      <key>Value</key>
 +      <integer>1</integer>
 +    </map>
 +  </map>
 +</llsd>
 diff --git a/indra/newview/character/avatar_lad.xml b/indra/newview/character/avatar_lad.xml index 10c197d09e..d7182dfaab 100644 --- a/indra/newview/character/avatar_lad.xml +++ b/indra/newview/character/avatar_lad.xml @@ -1,6 +1,6 @@  <?xml version="1.0" encoding="US-ASCII" standalone="yes"?>  <linden_avatar - version="1.0" wearable_definition_version="24">  + version="1.0" wearable_definition_version="22">     <!-- The wearable_definition_version is checked during asset upload. -->    <!-- If you increment it, check indra/lib/python/indra/assetutil.py.  -->    <skeleton diff --git a/indra/newview/installers/windows/FILES_ARE_UNICODE_UTF-16LE.txt b/indra/newview/installers/windows/FILES_ARE_UNICODE_UTF-16LE.txt index 30f9349111..185c0180fb 100644 --- a/indra/newview/installers/windows/FILES_ARE_UNICODE_UTF-16LE.txt +++ b/indra/newview/installers/windows/FILES_ARE_UNICODE_UTF-16LE.txt @@ -1,6 +1,6 @@ -The language files in this directory are Unicode (Little-Endian) format, also known as UTF-16 LE. - -This is the format required for NSIS Unicode.  See http://www.scratchpaper.com/ for details. - -James Cook -September 2008 +The language files in this directory are Unicode (Little-Endian) format, also known as UTF-16 LE.
 +
 +This is the format required for NSIS Unicode.  See http://www.scratchpaper.com/ for details.
 +
 +James Cook
 +September 2008
 diff --git a/indra/newview/llagent.cpp b/indra/newview/llagent.cpp index 1257cf9789..fb2ecb3bed 100644 --- a/indra/newview/llagent.cpp +++ b/indra/newview/llagent.cpp @@ -31,84 +31,54 @@   */  #include "llviewerprecompiledheaders.h" -  #include "llagent.h"  -#include "llagentwearables.h" + +#include "pipeline.h"  #include "llagentlistener.h" +#include "llagentwearables.h" +#include "llagentui.h" +  #include "llanimationstates.h" +#include "llbottomtray.h"  #include "llcallingcard.h" +#include "llchannelmanager.h"  #include "llconsole.h" -#include "lldrawable.h"  #include "llfirstuse.h" -#include "llfloaterreg.h" -#include "llspeakers.h"  #include "llfloatercamera.h"  #include "llfloatercustomize.h" - -#include "llfloaterland.h" -#include "llfloatersnapshot.h" +#include "llfloaterreg.h"  #include "llfloatertools.h" -#include "llfloaterworldmap.h" -  #include "llgroupactions.h" - -#include "llfocusmgr.h"  #include "llgroupmgr.h"  #include "llhomelocationresponder.h" -#include "llimview.h"  #include "llhudmanager.h"  #include "lljoystickbutton.h" -#include "llmenugl.h"  #include "llmorphview.h"  #include "llmoveview.h" +#include "llnavigationbar.h" // to show/hide navigation bar when changing mouse look state +#include "llnearbychatbar.h"  #include "llparcel.h" -#include "llquantize.h" -#include "llrand.h" -#include "llregionhandle.h"  #include "llsdutil.h" -#include "llselectmgr.h" +#include "llsidetray.h"  #include "llsky.h" -#include "llslurl.h"  #include "llsmoothstep.h" -#include "llsidetray.h"  #include "llstatusbar.h" -#include "llteleportflags.h" -#include "llteleporthistory.h" -#include "lltexturestats.h" -#include "lltexturestats.h"  #include "lltool.h" -#include "lltoolcomp.h"  #include "lltoolmgr.h" -#include "lluictrlfactory.h" -#include "llurldispatcher.h" - -#include "llviewercamera.h" +#include "lltrans.h" +#include "llviewercontrol.h"  #include "llviewerdisplay.h" +#include "llviewerjoystick.h"  #include "llviewermediafocus.h"  #include "llviewerobjectlist.h"  #include "llviewerparcelmgr.h"  #include "llviewerstats.h" -#include "llviewerwindow.h" -#include "llviewercontrol.h" -#include "llviewerjoystick.h" -  #include "llvoavatarself.h"  #include "llwindow.h"  #include "llworld.h"  #include "llworldmap.h" -#include "pipeline.h" -#include "lltrans.h" -#include "llbottomtray.h" -#include "llnearbychatbar.h" -#include "stringize.h" -#include "llcapabilitylistener.h" - -#include "llnavigationbar.h" //to show/hide navigation bar when changing mouse look state -#include "llagentui.h" -#include "llchannelmanager.h" -  using namespace LLVOAvatarDefines;  extern LLMenuBarGL* gMenuBarView; @@ -6356,7 +6326,7 @@ void LLAgent::sendAgentSetAppearance()  			msg->addU8Fast(_PREHASH_TextureIndex, (U8)texture_index);  		}  		msg->nextBlockFast(_PREHASH_ObjectData); -		mAvatarObject->packTEMessage( gMessageSystem ); +		mAvatarObject->sendAppearanceMessage( gMessageSystem );  	}  	else  	{ diff --git a/indra/newview/llagent.h b/indra/newview/llagent.h index 99a9bdd8e6..4162dfce1e 100644 --- a/indra/newview/llagent.h +++ b/indra/newview/llagent.h @@ -36,14 +36,13 @@  #include "indra_constants.h"  #include "llevent.h" 				// LLObservable base class  #include "llagentaccess.h" -#include "llagentaccess.h"  #include "llagentconstants.h" -#include "llhudeffectpointat.h" 	// ELookAtType -#include "llhudeffectlookat.h" 		// EPointAtType -#include "llpointer.h" +#include "llagentdata.h" 			// gAgentID, gAgentSessionID  #include "llcharacter.h" 			// LLAnimPauseRequest  #include "llfollowcam.h" 			// Ventrella -#include "llagentdata.h" 			// gAgentID, gAgentSessionID +#include "llhudeffectlookat.h" 		// EPointAtType +#include "llhudeffectpointat.h" 	// ELookAtType +#include "llpointer.h"  #include "lluicolor.h"  #include "llvoavatardefines.h" diff --git a/indra/newview/llagentwearables.cpp b/indra/newview/llagentwearables.cpp index 6cb96d1336..538dcb6f3d 100644 --- a/indra/newview/llagentwearables.cpp +++ b/indra/newview/llagentwearables.cpp @@ -62,7 +62,7 @@ class LLInitialWearablesFetch : public LLInventoryFetchDescendentsObserver  {  public:  	LLInitialWearablesFetch() {} -	~LLInitialWearablesFetch() {} +	~LLInitialWearablesFetch();  	virtual void done();  	struct InitialWearableData @@ -84,7 +84,6 @@ public:  protected:  	void processWearablesMessage();  	void processContents(); -	static void onIdle(void *userdata);  };  class LLLibraryOutfitsFetch : public LLInventoryFetchDescendentsObserver @@ -654,11 +653,13 @@ LLWearable* LLAgentWearables::getWearable(const EWearableType type, U32 index)  void LLAgentWearables::setWearable(const EWearableType type, U32 index, LLWearable *wearable)  { -	if (!getWearable(type,index)) +	LLWearable *old_wearable = getWearable(type,index); +	if (!old_wearable)  	{  		pushWearable(type,wearable);  		return;  	} +	  	wearableentry_map_t::iterator wearable_iter = mWearableDatas.find(type);  	if (wearable_iter == mWearableDatas.end())  	{ @@ -673,6 +674,7 @@ void LLAgentWearables::setWearable(const EWearableType type, U32 index, LLWearab  	else  	{  		wearable_vec[index] = wearable; +		old_wearable->setLabelUpdated();  		mAvatarObject->wearableUpdated(wearable->getType());  	}  } @@ -689,6 +691,7 @@ U32 LLAgentWearables::pushWearable(const EWearableType type, LLWearable *wearabl  	{  		mWearableDatas[type].push_back(wearable);  		mAvatarObject->wearableUpdated(wearable->getType()); +		wearable->setLabelUpdated();  		return mWearableDatas[type].size()-1;  	}  	return MAX_WEARABLES_PER_TYPE; @@ -718,6 +721,7 @@ void LLAgentWearables::popWearable(const EWearableType type, U32 index)  	{  		mWearableDatas[type].erase(mWearableDatas[type].begin() + index);  		mAvatarObject->wearableUpdated(wearable->getType()); +		wearable->setLabelUpdated();  	}  } @@ -1413,14 +1417,10 @@ void LLAgentWearables::removeWearableFinal(const EWearableType type, bool do_rem  		for (S32 i=max_entry; i>=0; i--)  		{  			LLWearable* old_wearable = getWearable(type,i); -			const LLUUID &item_id = getWearableItemID(type,i); -			popWearable(type,i); -			gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); -			LLAppearanceManager::instance().removeItemLinks(item_id,false); -  			//queryWearableCache(); // moved below  			if (old_wearable)  			{ +				popWearable(old_wearable);  				old_wearable->removeFromAvatar(TRUE);  			}  		} @@ -1429,16 +1429,11 @@ void LLAgentWearables::removeWearableFinal(const EWearableType type, bool do_rem  	else  	{  		LLWearable* old_wearable = getWearable(type, index); - -		const LLUUID &item_id = getWearableItemID(type,index); -		popWearable(type, index); -		gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); -		LLAppearanceManager::instance().removeItemLinks(item_id,false); -  		//queryWearableCache(); // moved below  		if (old_wearable)  		{ +			popWearable(old_wearable);  			old_wearable->removeFromAvatar(TRUE);  		}  	} @@ -1500,7 +1495,6 @@ void LLAgentWearables::setWearableOutfit(const LLInventoryItem::item_array_t& it  				continue;  			} -			gInventory.addChangedMask(LLInventoryObserver::LABEL, old_item_id);  			// Assumes existing wearables are not dirty.  			if (old_wearable->isDirty())  			{ @@ -1509,9 +1503,9 @@ void LLAgentWearables::setWearableOutfit(const LLInventoryItem::item_array_t& it  			}  		} -		setWearable(type,0,new_wearable);  		if (new_wearable)  			new_wearable->setItemID(new_item->getUUID()); +		setWearable(type,0,new_wearable);  	}  	std::vector<LLWearable*> wearables_being_removed; @@ -2159,6 +2153,11 @@ void LLLibraryOutfitsFetch::contentsDone(void)  // to avoid gInventory.notifyObservers recursion.  //-------------------------------------------------------------------- +LLInitialWearablesFetch::~LLInitialWearablesFetch() +{ +	llinfos << "~LLInitialWearablesFetch" << llendl; +} +  // virtual  void LLInitialWearablesFetch::done()  { @@ -2166,15 +2165,7 @@ void LLInitialWearablesFetch::done()  	// gInventory.notifyObservers.  The results will be handled in the next  	// idle tick instead.  	gInventory.removeObserver(this); -	gIdleCallbacks.addFunction(onIdle, this); -} - -// static -void LLInitialWearablesFetch::onIdle(void *data) -{ -	gIdleCallbacks.deleteFunction(onIdle, data); -	LLInitialWearablesFetch *self = reinterpret_cast<LLInitialWearablesFetch*>(data); -	self->processContents(); +	doOnIdle(boost::bind(&LLInitialWearablesFetch::processContents,this));  }  void LLInitialWearablesFetch::processContents() diff --git a/indra/newview/llappearancemgr.cpp b/indra/newview/llappearancemgr.cpp index 80ac9e4085..d6265a85f6 100644 --- a/indra/newview/llappearancemgr.cpp +++ b/indra/newview/llappearancemgr.cpp @@ -40,7 +40,7 @@  #include "llinventorybridge.h"  #include "llinventoryobserver.h"  #include "llnotifications.h" -#include "llpanelappearance.h" +#include "llsidepanelappearance.h"  #include "llsidetray.h"  #include "llvoavatar.h"  #include "llvoavatarself.h" @@ -96,7 +96,8 @@ public:  		mAppend(append)  	{}  	~LLOutfitObserver() {} -	virtual void done(); //public +	virtual void done(); +	void doWearCategory();  protected:  	LLUUID mCatID; @@ -106,6 +107,12 @@ protected:  void LLOutfitObserver::done()  { +	gInventory.removeObserver(this); +	doOnIdle(boost::bind(&LLOutfitObserver::doWearCategory,this)); +} + +void LLOutfitObserver::doWearCategory() +{  	// We now have an outfit ready to be copied to agent inventory. Do  	// it, and wear that outfit normally.  	if(mCopyItems) @@ -175,6 +182,7 @@ void LLOutfitObserver::done()  		// Wear the inventory category.  		LLAppearanceManager::instance().wearInventoryCategoryOnAvatar(gInventory.getCategory(mCatID), mAppend);  	} +	delete this;  }  class LLOutfitFetch : public LLInventoryFetchDescendentsObserver @@ -222,7 +230,6 @@ void LLOutfitFetch::done()  	// loop.  	//dec_busy_count();  	gInventory.removeObserver(this); -	delete this;  	// increment busy count and either tell the inventory to check &  	// call done, or add this object to the inventory for observation. @@ -241,6 +248,7 @@ void LLOutfitFetch::done()  		// will call done for us when everything is here.  		gInventory.addObserver(outfit_observer);  	} +	delete this;  }  class LLUpdateAppearanceOnDestroy: public LLInventoryCallback @@ -457,7 +465,7 @@ void LLAppearanceManager::filterWearableItems(  // Create links to all listed items.  void LLAppearanceManager::linkAll(const LLUUID& category,  								  LLInventoryModel::item_array_t& items, -											   LLPointer<LLInventoryCallback> cb) +								  LLPointer<LLInventoryCallback> cb)  {  	for (S32 i=0; i<items.count(); i++)  	{ @@ -530,10 +538,10 @@ void LLAppearanceManager::updateCOF(const LLUUID& category, bool append)  							LLAssetType::AT_LINK_FOLDER, link_waiter);  		// Update the current outfit name of the appearance sidepanel. -		LLPanelAppearance* panel_appearance = dynamic_cast<LLPanelAppearance *>(LLSideTray::getInstance()->getPanel("panel_appearance")); +		LLSidepanelAppearance* panel_appearance = dynamic_cast<LLSidepanelAppearance *>(LLSideTray::getInstance()->getPanel("sidepanel_appearance"));  		if (panel_appearance)  		{ -			panel_appearance->refreshCurrentLookName(catp->getName()); +			panel_appearance->refreshCurrentOutfitName(catp->getName());  		}  	} @@ -571,7 +579,6 @@ void LLAppearanceManager::updateAgentWearables(LLWearableHoldingPattern* holder,  	if(wearables.count() > 0)  	{  		gAgentWearables.setWearableOutfit(items, wearables, !append); -		gInventory.notifyObservers();  	}  	delete holder; @@ -811,15 +818,23 @@ bool areMatchingWearables(const LLViewerInventoryItem *a, const LLViewerInventor  			(a->getWearableType() == b->getWearableType()));  } -void LLAppearanceManager::addItemLink( LLInventoryItem* item, bool do_update ) +void LLAppearanceManager::addCOFItemLink(const LLUUID &item_id, bool do_update )  { -	LLViewerInventoryItem *vitem = dynamic_cast<LLViewerInventoryItem*>(item); +	const LLInventoryItem *item = gInventory.getItem(item_id); +	addCOFItemLink(item); +} + +void LLAppearanceManager::addCOFItemLink(const LLInventoryItem *item, bool do_update ) +{		 +	const LLViewerInventoryItem *vitem = dynamic_cast<const LLViewerInventoryItem*>(item);  	if (!vitem)  	{  		llwarns << "not an llviewerinventoryitem, failed" << llendl;  		return;  	} -		 + +	gInventory.addChangedMask(LLInventoryObserver::LABEL, vitem->getLinkedUUID()); +  	LLInventoryModel::cat_array_t cat_array;  	LLInventoryModel::item_array_t item_array;  	gInventory.collectDescendents(LLAppearanceManager::getCOF(), @@ -831,7 +846,7 @@ void LLAppearanceManager::addItemLink( LLInventoryItem* item, bool do_update )  	{  		// Are these links to the same object?  		const LLViewerInventoryItem* inv_item = item_array.get(i).get(); -		if (inv_item->getLinkedUUID() == item->getLinkedUUID()) +		if (inv_item->getLinkedUUID() == vitem->getLinkedUUID())  		{  			linked_already = true;  		} @@ -842,7 +857,6 @@ void LLAppearanceManager::addItemLink( LLInventoryItem* item, bool do_update )  		{  			gAgentWearables.removeWearable(inv_item->getWearableType(),true,0);  			gInventory.purgeObject(inv_item->getUUID()); -			gInventory.notifyObservers();  		}  	}  	if (linked_already) @@ -878,8 +892,10 @@ void LLAppearanceManager::addEnsembleLink( LLInventoryCategory* cat, bool do_upd  #endif  } -void LLAppearanceManager::removeItemLinks(const LLUUID& item_id, bool do_update) +void LLAppearanceManager::removeCOFItemLinks(const LLUUID& item_id, bool do_update)  { +	gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); +  	LLInventoryModel::cat_array_t cat_array;  	LLInventoryModel::item_array_t item_array;  	gInventory.collectDescendents(LLAppearanceManager::getCOF(), @@ -891,7 +907,8 @@ void LLAppearanceManager::removeItemLinks(const LLUUID& item_id, bool do_update)  		const LLInventoryItem* item = item_array.get(i).get();  		if (item->getLinkedUUID() == item_id)  		{ -			gInventory.purgeObject(item_array.get(i)->getUUID()); +			const LLUUID& item_id = item_array.get(i)->getUUID(); +			gInventory.purgeObject(item_id);  		}  	}  	if (do_update) @@ -970,18 +987,13 @@ void dumpAttachmentSet(const std::set<LLUUID>& atts, const std::string& msg)  void LLAppearanceManager::registerAttachment(const LLUUID& item_id)  {         mRegisteredAttachments.insert(item_id); +	   gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id);         //dumpAttachmentSet(mRegisteredAttachments,"after register:");  	   if (mAttachmentInvLinkEnabled)  	   { -		   LLViewerInventoryItem *item = gInventory.getItem(item_id); -		   if (item) -		   { -			   //LLAppearanceManager::dumpCat(LLAppearanceManager::getCOF(),"Adding attachment link:"); -			   LLAppearanceManager::addItemLink(item,false);  // Add COF link for item. -			   gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); -			   gInventory.notifyObservers(); -		   } +		   //LLAppearanceManager::dumpCat(LLAppearanceManager::getCOF(),"Adding attachment link:"); +		   LLAppearanceManager::addCOFItemLink(item_id, false);  // Add COF link for item.  	   }  	   else  	   { @@ -992,15 +1004,14 @@ void LLAppearanceManager::registerAttachment(const LLUUID& item_id)  void LLAppearanceManager::unregisterAttachment(const LLUUID& item_id)  {         mRegisteredAttachments.erase(item_id); +	   gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); +         //dumpAttachmentSet(mRegisteredAttachments,"after unregister:");  	   if (mAttachmentInvLinkEnabled)  	   {  		   //LLAppearanceManager::dumpCat(LLAppearanceManager::getCOF(),"Removing attachment link:"); -		   LLAppearanceManager::removeItemLinks(item_id, false); -		   // BAP - needs to change for label to track link. -		   gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); -		   gInventory.notifyObservers(); +		   LLAppearanceManager::removeCOFItemLinks(item_id, false);  	   }  	   else  	   { @@ -1015,13 +1026,7 @@ void LLAppearanceManager::linkRegisteredAttachments()  		 ++it)  	{  		LLUUID item_id = *it; -		LLViewerInventoryItem *item = gInventory.getItem(item_id); -		if (item) -		{ -			addItemLink(item, false); -			gInventory.addChangedMask(LLInventoryObserver::LABEL, item_id); -			gInventory.notifyObservers(); -		} +		addCOFItemLink(item_id, false);  	}  	mRegisteredAttachments.clear();  } diff --git a/indra/newview/llappearancemgr.h b/indra/newview/llappearancemgr.h index 88d3320d1f..5daa6d067b 100644 --- a/indra/newview/llappearancemgr.h +++ b/indra/newview/llappearancemgr.h @@ -36,6 +36,7 @@  #include "llsingleton.h"  #include "llinventorymodel.h"  #include "llviewerinventory.h" +#include "llcallbacklist.h"  class LLWearable;  struct LLWearableHoldingPattern; @@ -53,12 +54,6 @@ public:  	void wearOutfitByName(const std::string& name);  	void changeOutfit(bool proceed, const LLUUID& category, bool append); -	// Add COF link to individual item. -	void addItemLink(LLInventoryItem* item, bool do_update = true); - -	// Add COF link to ensemble folder. -	void addEnsembleLink(LLInventoryCategory* item, bool do_update = true); -  	// Copy all items in a category.  	void shallowCopyCategory(const LLUUID& src_id, const LLUUID& dst_id,  							 LLPointer<LLInventoryCallback> cb); @@ -66,9 +61,6 @@ public:  	// Find the Current Outfit folder.  	LLUUID getCOF(); -	// Remove COF entries -	void removeItemLinks(const LLUUID& item_id, bool do_update = true); -  	void updateAgentWearables(LLWearableHoldingPattern* holder, bool append);  	// For debugging - could be moved elsewhere. @@ -81,6 +73,21 @@ public:  	void setAttachmentInvLinkEnable(bool val);  	void linkRegisteredAttachments(); +	// utility function for bulk linking. +	void linkAll(const LLUUID& category, +				 LLInventoryModel::item_array_t& items, +				 LLPointer<LLInventoryCallback> cb); + +	// Add COF link to individual item. +	void addCOFItemLink(const LLUUID& item_id, bool do_update = true); +	void addCOFItemLink(const LLInventoryItem *item, bool do_update = true); + +	// Remove COF entries +	void removeCOFItemLinks(const LLUUID& item_id, bool do_update = true); + +	// Add COF link to ensemble folder. +	void addEnsembleLink(LLInventoryCategory* item, bool do_update = true); +  protected:  	LLAppearanceManager();  	~LLAppearanceManager(); @@ -88,9 +95,6 @@ protected:  private:  	void filterWearableItems(LLInventoryModel::item_array_t& items, S32 max_per_type); -	void linkAll(const LLUUID& category, -						LLInventoryModel::item_array_t& items, -						LLPointer<LLInventoryCallback> cb);  	void getDescendentsOfAssetType(const LLUUID& category,   										  LLInventoryModel::item_array_t& items, @@ -111,4 +115,36 @@ private:  #define SUPPORT_ENSEMBLES 0 +// Shim class and template function to allow arbitrary boost::bind +// expressions to be run as one-time idle callbacks. +template <typename T> +class OnIdleCallback +{ +public: +	OnIdleCallback(T callable): +		mCallable(callable) +	{ +	} +	static void onIdle(void *data) +	{ +		gIdleCallbacks.deleteFunction(onIdle, data); +		OnIdleCallback<T>* self = reinterpret_cast<OnIdleCallback<T>*>(data); +		self->call(); +		delete self; +	} +	void call() +	{ +		mCallable(); +	} +private: +	T mCallable; +}; + +template <typename T> +void doOnIdle(T callable) +{ +	OnIdleCallback<T>* cb_functor = new OnIdleCallback<T>(callable); +	gIdleCallbacks.addFunction(&OnIdleCallback<T>::onIdle,cb_functor); +} +  #endif diff --git a/indra/newview/llappviewer.cpp b/indra/newview/llappviewer.cpp index 445ff5f08e..a5ca06ce30 100644 --- a/indra/newview/llappviewer.cpp +++ b/indra/newview/llappviewer.cpp @@ -3534,6 +3534,7 @@ void LLAppViewer::idle()  		gEventNotifier.update();  		gIdleCallbacks.callFunctions(); +		gInventory.notifyObservers();  	}  	if (gDisconnected) diff --git a/indra/newview/llcallingcard.h b/indra/newview/llcallingcard.h index bd58b2fbe6..47b0dcb903 100644 --- a/indra/newview/llcallingcard.h +++ b/indra/newview/llcallingcard.h @@ -45,6 +45,7 @@  //class LLInventoryObserver;  class LLMessageSystem;  class LLTrackingData; +  class LLFriendObserver  {  public: diff --git a/indra/newview/llfloateruipreview.cpp b/indra/newview/llfloateruipreview.cpp index 3613ac803e..a1c6704657 100644 --- a/indra/newview/llfloateruipreview.cpp +++ b/indra/newview/llfloateruipreview.cpp @@ -431,9 +431,9 @@ BOOL LLFloaterUIPreview::postBuild()  	// get pointers to buttons and link to callbacks  	mLanguageSelection = main_panel_tmp->getChild<LLComboBox>("language_select_combo"); -	mLanguageSelection->setSelectionCallback(boost::bind(&LLFloaterUIPreview::onLanguageComboSelect, this, mLanguageSelection)); +	mLanguageSelection->setCommitCallback(boost::bind(&LLFloaterUIPreview::onLanguageComboSelect, this, mLanguageSelection));  	mLanguageSelection_2 = main_panel_tmp->getChild<LLComboBox>("language_select_combo_2"); -	mLanguageSelection_2->setSelectionCallback(boost::bind(&LLFloaterUIPreview::onLanguageComboSelect, this, mLanguageSelection)); +	mLanguageSelection_2->setCommitCallback(boost::bind(&LLFloaterUIPreview::onLanguageComboSelect, this, mLanguageSelection));  	LLPanel* editor_panel_tmp = main_panel_tmp->getChild<LLPanel>("editor_panel");  	mDisplayFloaterBtn = main_panel_tmp->getChild<LLButton>("display_floater");  	mDisplayFloaterBtn->setClickedCallback(boost::bind(&LLFloaterUIPreview::onClickDisplayFloater, this, PRIMARY_FLOATER)); diff --git a/indra/newview/llfolderviewitem.cpp b/indra/newview/llfolderviewitem.cpp index d39a17ca3b..7323c421da 100644 --- a/indra/newview/llfolderviewitem.cpp +++ b/indra/newview/llfolderviewitem.cpp @@ -133,8 +133,8 @@ LLFolderViewItem::LLFolderViewItem(LLFolderViewItem::Params p)  	mIconOpen(p.icon_open),  	mListener(p.listener),  	mArrowImage(p.folder_arrow_image), -	mBoxImage(p.selection_image) -,	mDontShowInHierarhy(false) +	mBoxImage(p.selection_image), +	mDontShowInHierarchy(false)  {  	refresh();  } @@ -411,7 +411,7 @@ S32 LLFolderViewItem::arrange( S32* width, S32* height, S32 filter_generation)  S32 LLFolderViewItem::getItemHeight()  { -	if (mDontShowInHierarhy) return 0; +	if (mDontShowInHierarchy) return 0;  	S32 icon_height = mIcon->getHeight();  	S32 label_height = llround(getLabelFontForStyle(mLabelStyle)->getLineHeight()); @@ -819,7 +819,7 @@ BOOL LLFolderViewItem::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop,  void LLFolderViewItem::draw()  { -	if (mDontShowInHierarhy) return; +	if (mDontShowInHierarchy) return;  	static LLUIColor sFgColor = LLUIColorTable::instance().getColor("MenuItemEnabledColor", DEFAULT_WHITE);  	static LLUIColor sHighlightBgColor = LLUIColorTable::instance().getColor("MenuItemHighlightBgColor", DEFAULT_WHITE); @@ -995,14 +995,14 @@ void LLFolderViewItem::draw()  				S32 right = left + font->getWidth(combined_string, mStringMatchOffset, filter_string_length) + 2;  				S32 bottom = llfloor(getRect().getHeight() - font->getLineHeight() - 3);  				S32 top = getRect().getHeight(); - +				  				LLRect box_rect(left, top, right, bottom);  				sBoxImage->draw(box_rect, sFilterBGColor);  				F32 match_string_left = text_left + font->getWidthF32(combined_string, 0, mStringMatchOffset);  				F32 y = (F32)getRect().getHeight() - font->getLineHeight() - (F32)TEXT_PAD;  				font->renderUTF8( combined_string, mStringMatchOffset, match_string_left, y, -						   sFilterTextColor, LLFontGL::LEFT, LLFontGL::BOTTOM, LLFontGL::NORMAL, LLFontGL::NO_SHADOW, -					filter_string_length, S32_MAX, &right_x, FALSE ); +								  sFilterTextColor, LLFontGL::LEFT, LLFontGL::BOTTOM, LLFontGL::NORMAL, LLFontGL::NO_SHADOW, +								  filter_string_length, S32_MAX, &right_x, FALSE );  			}  		}  	} @@ -1253,6 +1253,10 @@ void LLFolderViewFolder::filter( LLInventoryFilter& filter)  			// filter self only on first pass through  			LLFolderViewItem::filter( filter );  		} +		if (mDontShowInHierarchy) +		{ +			setOpen(); +		}  	}  	if (getRoot()->getDebugFilters()) @@ -2166,6 +2170,7 @@ BOOL LLFolderViewFolder::handleMouseDown( S32 x, S32 y, MASK mask )  BOOL LLFolderViewFolder::handleDoubleClick( S32 x, S32 y, MASK mask )  { +	/* Disable outfit double click to wear  	const LLUUID &cat_uuid = getListener()->getUUID();  	const LLViewerInventoryCategory *cat = gInventory.getCategory(cat_uuid);  	if (cat && cat->getPreferredType() == LLFolderType::FT_OUTFIT) @@ -2173,6 +2178,7 @@ BOOL LLFolderViewFolder::handleDoubleClick( S32 x, S32 y, MASK mask )  		getListener()->performAction(NULL, NULL,"replaceoutfit");  		return TRUE;  	} +	*/  	BOOL handled = FALSE;  	if( mIsOpen ) diff --git a/indra/newview/llfolderviewitem.h b/indra/newview/llfolderviewitem.h index 7c429fc76e..30387812a6 100644 --- a/indra/newview/llfolderviewitem.h +++ b/indra/newview/llfolderviewitem.h @@ -158,7 +158,7 @@ protected:  	LLUIImagePtr				mBoxImage;  	BOOL                            mIsLoading;  	LLTimer                         mTimeSinceRequestStart; -	bool						mDontShowInHierarhy; +	bool						mDontShowInHierarchy;  	// helper function to change the selection from the root.  	void changeSelectionFromRoot(LLFolderViewItem* selection, BOOL selected); @@ -201,8 +201,8 @@ public:  	// makes sure that this view and it's children are the right size.  	virtual S32 arrange( S32* width, S32* height, S32 filter_generation );  	virtual S32 getItemHeight(); -	void setDontShowInHierarchy(bool dont_show) { mDontShowInHierarhy = dont_show; } -	bool getDontShowInHierarchy() { return mDontShowInHierarhy; } +	void setDontShowInHierarchy(bool dont_show) { mDontShowInHierarchy = dont_show; } +	bool getDontShowInHierarchy() { return mDontShowInHierarchy; }  	// applies filters to control visibility of inventory items  	virtual void filter( LLInventoryFilter& filter); @@ -343,7 +343,7 @@ typedef bool (*sort_order_f)(LLFolderViewItem* a, LLFolderViewItem* b);  //  // An instance of an LLFolderViewFolder represents a collection of  // more folders and items. This is used to build the hierarchy of -// items found in the folder view. :) +// items found in the folder view.  //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  class LLFolderViewFolder : public LLFolderViewItem diff --git a/indra/newview/llinventorybridge.cpp b/indra/newview/llinventorybridge.cpp index d18f9affe3..384d2ae671 100644 --- a/indra/newview/llinventorybridge.cpp +++ b/indra/newview/llinventorybridge.cpp @@ -31,73 +31,37 @@   */
  #include "llviewerprecompiledheaders.h"
 -
 -#include <utility> // for std::pair<>
 -
 -#include "llfloaterinventory.h"
  #include "llinventorybridge.h"
 -#include "message.h"
 -
  #include "llagent.h"
  #include "llagentwearables.h"
 -#include "llcallingcard.h"
 -#include "llcheckboxctrl.h"		// for radio buttons
 -#include "llfloaterreg.h"
 -#include "llradiogroup.h"
 -#include "llspinctrl.h"
 -#include "lltextbox.h"
 -#include "llui.h"
 -
 -#include "llviewercontrol.h"
 -#include "llfirstuse.h"
 -#include "llfoldertype.h"
 -#include "llfloaterchat.h"
 +#include "llappearancemgr.h"
 +#include "llavataractions.h"
  #include "llfloatercustomize.h"
 -#include "llfloaterproperties.h"
 +#include "llfloaterinventory.h"
 +#include "llfloateropenobject.h"
 +#include "llfloaterreg.h"
  #include "llfloaterworldmap.h"
 -#include "llfocusmgr.h"
 -#include "llfolderview.h"
  #include "llfriendcard.h"
 -#include "llavataractions.h"
  #include "llgesturemgr.h"
 -#include "lliconctrl.h"
 +#include "llimfloater.h"
 +#include "llimview.h"
 +#include "llinventoryclipboard.h"
  #include "llinventoryfunctions.h"
  #include "llinventorymodel.h"
  #include "llinventorypanel.h"
 -#include "llinventoryclipboard.h"
 -#include "lllineeditor.h"
 -#include "llmenugl.h"
  #include "llpreviewanim.h"
  #include "llpreviewgesture.h"
 -#include "llpreviewnotecard.h"
 -#include "llpreviewscript.h"
 -#include "llpreviewsound.h"
  #include "llpreviewtexture.h"
 -#include "llresmgr.h"
 -#include "llscrollcontainer.h"
 -#include "llimview.h"
 -#include "lltooldraganddrop.h"
 -#include "llviewerfoldertype.h"
 -#include "llviewertexturelist.h"
 -#include "llviewerinventory.h"
 -#include "llviewerobjectlist.h"
 -#include "llviewerwindow.h"
 -#include "llvoavatar.h"
 -#include "llwearable.h"
 -#include "llwearablelist.h"
 -#include "llviewerassettype.h"
 -#include "llviewermessage.h"
 -#include "llviewerregion.h"
 -#include "llvoavatarself.h"
 -#include "lltabcontainer.h"
 -#include "lluictrlfactory.h"
  #include "llselectmgr.h"
  #include "llsidetray.h"
 -#include "llfloateropenobject.h"
  #include "lltrans.h"
 -#include "llappearancemgr.h"
 -#include "llimfloater.h"
 +#include "llviewerassettype.h"
 +#include "llviewermessage.h"
 +#include "llviewerobjectlist.h"
 +#include "llviewerwindow.h"
 +#include "llvoavatarself.h"
 +#include "llwearablelist.h"
  using namespace LLOldEvents;
 @@ -162,16 +126,6 @@ std::string ICON_NAME[ICON_NAME_COUNT] =  	"inv_item_linkfolder.tga"
  };
 -
 -// +=================================================+
 -// |        LLInventoryPanelObserver                 |
 -// +=================================================+
 -void LLInventoryPanelObserver::changed(U32 mask)
 -{
 -	mIP->modelChanged(mask);
 -}
 -
 -
  // +=================================================+
  // |        LLInvFVBridge                            |
  // +=================================================+
 @@ -229,37 +183,6 @@ BOOL LLInvFVBridge::isItemRemovable()  	return FALSE;
  }
 -// Sends an update to all link items that point to the base item.
 -void LLInvFVBridge::renameLinkedItems(const LLUUID &item_id, const std::string& new_name)
 -{
 -	LLInventoryModel* model = getInventoryModel();
 -	if(!model) return;
 -
 -	LLInventoryItem* itemp = model->getItem(mUUID);
 -	if (!itemp) return;
 -
 -	if (itemp->getIsLinkType())
 -	{
 -		return;
 -	}
 -
 -	LLInventoryModel::item_array_t item_array = model->collectLinkedItems(item_id);
 -	for (LLInventoryModel::item_array_t::iterator iter = item_array.begin();
 -		 iter != item_array.end();
 -		 iter++)
 -	{
 -		LLViewerInventoryItem *linked_item = (*iter);
 -		if (linked_item->getUUID() == item_id) continue;
 -
 -		LLPointer<LLViewerInventoryItem> new_item = new LLViewerInventoryItem(linked_item);
 -		new_item->rename(new_name);
 -		new_item->updateServer(FALSE);
 -		model->updateItem(new_item);
 -		// model->addChangedMask(LLInventoryObserver::LABEL, linked_item->getUUID());
 -	}
 -	model->notifyObservers();
 -}
 -
  // Can be moved to another folder
  BOOL LLInvFVBridge::isItemMovable() const
  {
 @@ -1682,6 +1605,25 @@ BOOL LLFolderBridge::dragCategoryIntoFolder(LLInventoryCategory* inv_cat,  			// if target is an outfit or current outfit folder we use link
  			if (move_is_into_current_outfit || move_is_into_outfit)
  			{
 +				if (inv_cat->getPreferredType() == LLFolderType::FT_NONE)
 +				{
 +					if (move_is_into_current_outfit)
 +					{
 +						// traverse category and add all contents to currently worn.
 +						BOOL append = true;
 +						LLAppearanceManager::instance().wearInventoryCategory(inv_cat, false, append);
 +					}
 +					else
 +					{
 +						// Recursively create links in target outfit.
 +						LLInventoryModel::cat_array_t cats;
 +						LLInventoryModel::item_array_t items;
 +						gInventory.collectDescendents(inv_cat->getUUID(), cats, items, LLInventoryModel::EXCLUDE_TRASH);
 +						LLAppearanceManager::instance().linkAll(mUUID,items,NULL);
 +					}
 +				}
 +				else
 +				{
  #if SUPPORT_ENSEMBLES
  				// BAP - should skip if dup.
  				if (move_is_into_current_outfit)
 @@ -1700,6 +1642,7 @@ BOOL LLFolderBridge::dragCategoryIntoFolder(LLInventoryCategory* inv_cat,  						cb);
  				}
  #endif
 +				}
  			}
  			else
  			{
 @@ -2888,9 +2831,11 @@ BOOL LLFolderBridge::dragItemIntoFolder(LLInventoryItem* inv_item,  		}
  		const LLUUID& favorites_id = model->findCategoryUUIDForType(LLFolderType::FT_FAVORITE);
 -
 +		const LLUUID& landmarks_id = model->findCategoryUUIDForType(LLFolderType::FT_LANDMARK);
 +		const BOOL folder_allows_reorder = ((mUUID == landmarks_id) || (mUUID == favorites_id));
 +	   
  		// we can move item inside a folder only if this folder is Favorites. See EXT-719
 -		accept = is_movable && ((mUUID != inv_item->getParentUUID()) || (mUUID == favorites_id));
 +		accept = is_movable && ((mUUID != inv_item->getParentUUID()) || folder_allows_reorder);
  		if(accept && drop)
  		{
  			if (inv_item->getType() == LLAssetType::AT_GESTURE
 @@ -2913,12 +2858,12 @@ BOOL LLFolderBridge::dragItemIntoFolder(LLInventoryItem* inv_item,  			}
  			// if dragging from/into favorites folder only reorder items
 -			if ((mUUID == inv_item->getParentUUID()) && (favorites_id == mUUID))
 +			if ((mUUID == inv_item->getParentUUID()) && folder_allows_reorder)
  			{
  				LLInventoryModel::cat_array_t cats;
  				LLInventoryModel::item_array_t items;
  				LLIsType is_type(LLAssetType::AT_LANDMARK);
 -				model->collectDescendentsIf(favorites_id, cats, items, LLInventoryModel::EXCLUDE_TRASH, is_type);
 +				model->collectDescendentsIf(mUUID, cats, items, LLInventoryModel::EXCLUDE_TRASH, is_type);
  				LLInventoryPanel* panel = dynamic_cast<LLInventoryPanel*>(mInventoryPanel.get());
  				LLFolderViewItem* itemp = panel ? panel->getRootFolder()->getDraggingOverItem() : NULL;
 @@ -2948,7 +2893,7 @@ BOOL LLFolderBridge::dragItemIntoFolder(LLInventoryItem* inv_item,  				// BAP - should skip if dup.
  				if (move_is_into_current_outfit)
  				{
 -					LLAppearanceManager::instance().addItemLink(inv_item);
 +					LLAppearanceManager::instance().addCOFItemLink(inv_item);
  				}
  				else
  				{
 @@ -4195,7 +4140,7 @@ void wear_inventory_item_on_avatar( LLInventoryItem* item )  		lldebugs << "wear_inventory_item_on_avatar( " << item->getName()
  				 << " )" << llendl;
 -		LLAppearanceManager::instance().addItemLink(item);
 +		LLAppearanceManager::instance().addCOFItemLink(item);
  	}
  }
 diff --git a/indra/newview/llinventorybridge.h b/indra/newview/llinventorybridge.h index 4c7b0a0517..49e64ebdde 100644 --- a/indra/newview/llinventorybridge.h +++ b/indra/newview/llinventorybridge.h @@ -107,22 +107,6 @@ struct LLAttachmentRezAction  	S32		mAttachPt;  }; - -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -// Class LLInventoryPanelObserver -// -// Bridge to support knowing when the inventory has changed. -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -class LLInventoryPanelObserver : public LLInventoryObserver -{ -public: -	LLInventoryPanelObserver(LLInventoryPanel* ip) : mIP(ip) {} -	virtual ~LLInventoryPanelObserver() {} -	virtual void changed(U32 mask); -protected: -	LLInventoryPanel* mIP; -}; -  const std::string safe_inv_type_lookup(LLInventoryType::EType inv_type);  void hide_context_entries(LLMenuGL& menu,   						const std::vector<std::string> &entries_to_show, @@ -220,8 +204,6 @@ protected:  									 const LLUUID& new_parent,  									 BOOL restamp);  	void removeBatchNoCheck(LLDynamicArray<LLFolderViewEventListener*>& batch); -	void renameLinkedItems(const LLUUID &item_id, const std::string& new_name); -  protected:  	LLHandle<LLPanel> mInventoryPanel;  	const LLUUID mUUID;	// item id diff --git a/indra/newview/llinventoryfilter.cpp b/indra/newview/llinventoryfilter.cpp index 7ec8d3d003..085c96c93d 100644 --- a/indra/newview/llinventoryfilter.cpp +++ b/indra/newview/llinventoryfilter.cpp @@ -100,13 +100,18 @@ BOOL LLInventoryFilter::check(LLFolderViewItem* item)  	bool passed_type = false;  	if (mFilterOps.mFilterForCategories)  	{ -		if (listener->getInventoryType() == LLInventoryType::IT_CATEGORY) +		// Pass if this item is a category of the filter type, or +		// if its parent is a category of the filter type. +		LLUUID uuid = listener->getUUID(); +		if (listener->getInventoryType() != LLInventoryType::IT_CATEGORY)  		{ -			LLViewerInventoryCategory *cat = gInventory.getCategory(listener->getUUID()); -			if (cat) -			{ -				passed_type |= ((1LL << cat->getPreferredType() & mFilterOps.mFilterTypes) != U64(0)); -			} +			const LLInventoryObject *obj = gInventory.getObject(uuid); +			uuid = obj->getParentUUID(); +		} +		LLViewerInventoryCategory *cat = gInventory.getCategory(uuid); +		if (cat) +		{ +			passed_type |= ((1LL << cat->getPreferredType() & mFilterOps.mFilterTypes) != U64(0));  		}  	}  	else diff --git a/indra/newview/llinventoryfunctions.h b/indra/newview/llinventoryfunctions.h index 95cc68ddbe..efd40576a7 100644 --- a/indra/newview/llinventoryfunctions.h +++ b/indra/newview/llinventoryfunctions.h @@ -1,136 +1,136 @@ -/**  - * @file llinventoryfunctions.h - * @brief Miscellaneous inventory-related functions and classes - * class definition - * - * $LicenseInfo:firstyear=2001&license=viewergpl$ - *  - * Copyright (c) 2001-2009, Linden Research, Inc. - *  - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab.  Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 - *  - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at - * http://secondlifegrid.net/programs/open_source/licensing/flossexception - *  - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - *  - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - * $/LicenseInfo$ - */ - -#ifndef LL_LLINVENTORYFUNCTIONS_H -#define LL_LLINVENTORYFUNCTIONS_H - -#include "llassetstorage.h" -#include "lldarray.h" -#include "llfloater.h" -#include "llinventory.h" -#include "llinventoryfilter.h" -#include "llfolderview.h" -#include "llinventorymodel.h" -#include "lluictrlfactory.h" -#include <set> - - -class LLFolderViewItem; -class LLInventoryFilter; -class LLInventoryModel; -class LLInventoryPanel; -class LLInvFVBridge; -class LLInventoryFVBridgeBuilder; -class LLMenuBarGL; -class LLCheckBoxCtrl; -class LLSpinCtrl; -class LLScrollContainer; -class LLTextBox; -class LLIconCtrl; -class LLSaveFolderState; -class LLFilterEditor; -class LLTabContainer; - -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -// -// This is a collection of miscellaneous functions and classes -// that don't fit cleanly into any other class header. -// -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -class LLInventoryState -{ -public: -	// HACK: Until we can route this info through the instant message hierarchy -	static BOOL sWearNewClothing; -	static LLUUID sWearNewClothingTransactionID;	// wear all clothing in this transaction	 -}; - -class LLSelectFirstFilteredItem : public LLFolderViewFunctor -{ -public: -	LLSelectFirstFilteredItem() : mItemSelected(FALSE) {} -	virtual ~LLSelectFirstFilteredItem() {} -	virtual void doFolder(LLFolderViewFolder* folder); -	virtual void doItem(LLFolderViewItem* item); -	BOOL wasItemSelected() { return mItemSelected; } -protected: -	BOOL	mItemSelected; -}; - -class LLOpenFilteredFolders : public LLFolderViewFunctor -{ -public: -	LLOpenFilteredFolders()  {} -	virtual ~LLOpenFilteredFolders() {} -	virtual void doFolder(LLFolderViewFolder* folder); -	virtual void doItem(LLFolderViewItem* item); -}; - -class LLSaveFolderState : public LLFolderViewFunctor -{ -public: -	LLSaveFolderState() : mApply(FALSE) {} -	virtual ~LLSaveFolderState() {} -	virtual void doFolder(LLFolderViewFolder* folder); -	virtual void doItem(LLFolderViewItem* item) {} -	void setApply(BOOL apply); -	void clearOpenFolders() { mOpenFolders.clear(); } -protected: -	std::set<LLUUID> mOpenFolders; -	BOOL mApply; -}; - -class LLOpenFoldersWithSelection : public LLFolderViewFunctor -{ -public: -	LLOpenFoldersWithSelection() {} -	virtual ~LLOpenFoldersWithSelection() {} -	virtual void doFolder(LLFolderViewFolder* folder); -	virtual void doItem(LLFolderViewItem* item); -}; - -const std::string& get_item_icon_name(LLAssetType::EType asset_type, -							 LLInventoryType::EType inventory_type, -							 U32 attachment_point,  -							 BOOL item_is_multi ); - -LLUIImagePtr get_item_icon(LLAssetType::EType asset_type, -							 LLInventoryType::EType inventory_type, -							 U32 attachment_point,  -							 BOOL item_is_multi ); - -#endif // LL_LLINVENTORYFUNCTIONS_H - - - +/** 
 + * @file llinventoryfunctions.h
 + * @brief Miscellaneous inventory-related functions and classes
 + * class definition
 + *
 + * $LicenseInfo:firstyear=2001&license=viewergpl$
 + * 
 + * Copyright (c) 2001-2009, Linden Research, Inc.
 + * 
 + * Second Life Viewer Source Code
 + * The source code in this file ("Source Code") is provided by Linden Lab
 + * to you under the terms of the GNU General Public License, version 2.0
 + * ("GPL"), unless you have obtained a separate licensing agreement
 + * ("Other License"), formally executed by you and Linden Lab.  Terms of
 + * the GPL can be found in doc/GPL-license.txt in this distribution, or
 + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
 + * 
 + * There are special exceptions to the terms and conditions of the GPL as
 + * it is applied to this Source Code. View the full text of the exception
 + * in the file doc/FLOSS-exception.txt in this software distribution, or
 + * online at
 + * http://secondlifegrid.net/programs/open_source/licensing/flossexception
 + * 
 + * By copying, modifying or distributing this software, you acknowledge
 + * that you have read and understood your obligations described above,
 + * and agree to abide by those obligations.
 + * 
 + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
 + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
 + * COMPLETENESS OR PERFORMANCE.
 + * $/LicenseInfo$
 + */
 +
 +#ifndef LL_LLINVENTORYFUNCTIONS_H
 +#define LL_LLINVENTORYFUNCTIONS_H
 +
 +#include "llassetstorage.h"
 +#include "lldarray.h"
 +#include "llfloater.h"
 +#include "llinventory.h"
 +#include "llinventoryfilter.h"
 +#include "llfolderview.h"
 +#include "llinventorymodel.h"
 +#include "lluictrlfactory.h"
 +#include <set>
 +
 +
 +class LLFolderViewItem;
 +class LLInventoryFilter;
 +class LLInventoryModel;
 +class LLInventoryPanel;
 +class LLInvFVBridge;
 +class LLInventoryFVBridgeBuilder;
 +class LLMenuBarGL;
 +class LLCheckBoxCtrl;
 +class LLSpinCtrl;
 +class LLScrollContainer;
 +class LLTextBox;
 +class LLIconCtrl;
 +class LLSaveFolderState;
 +class LLFilterEditor;
 +class LLTabContainer;
 +
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +//
 +// This is a collection of miscellaneous functions and classes
 +// that don't fit cleanly into any other class header.
 +//
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +
 +class LLInventoryState
 +{
 +public:
 +	// HACK: Until we can route this info through the instant message hierarchy
 +	static BOOL sWearNewClothing;
 +	static LLUUID sWearNewClothingTransactionID;	// wear all clothing in this transaction	
 +};
 +
 +class LLSelectFirstFilteredItem : public LLFolderViewFunctor
 +{
 +public:
 +	LLSelectFirstFilteredItem() : mItemSelected(FALSE) {}
 +	virtual ~LLSelectFirstFilteredItem() {}
 +	virtual void doFolder(LLFolderViewFolder* folder);
 +	virtual void doItem(LLFolderViewItem* item);
 +	BOOL wasItemSelected() { return mItemSelected; }
 +protected:
 +	BOOL	mItemSelected;
 +};
 +
 +class LLOpenFilteredFolders : public LLFolderViewFunctor
 +{
 +public:
 +	LLOpenFilteredFolders()  {}
 +	virtual ~LLOpenFilteredFolders() {}
 +	virtual void doFolder(LLFolderViewFolder* folder);
 +	virtual void doItem(LLFolderViewItem* item);
 +};
 +
 +class LLSaveFolderState : public LLFolderViewFunctor
 +{
 +public:
 +	LLSaveFolderState() : mApply(FALSE) {}
 +	virtual ~LLSaveFolderState() {}
 +	virtual void doFolder(LLFolderViewFolder* folder);
 +	virtual void doItem(LLFolderViewItem* item) {}
 +	void setApply(BOOL apply);
 +	void clearOpenFolders() { mOpenFolders.clear(); }
 +protected:
 +	std::set<LLUUID> mOpenFolders;
 +	BOOL mApply;
 +};
 +
 +class LLOpenFoldersWithSelection : public LLFolderViewFunctor
 +{
 +public:
 +	LLOpenFoldersWithSelection() {}
 +	virtual ~LLOpenFoldersWithSelection() {}
 +	virtual void doFolder(LLFolderViewFolder* folder);
 +	virtual void doItem(LLFolderViewItem* item);
 +};
 +
 +const std::string& get_item_icon_name(LLAssetType::EType asset_type,
 +							 LLInventoryType::EType inventory_type,
 +							 U32 attachment_point, 
 +							 BOOL item_is_multi );
 +
 +LLUIImagePtr get_item_icon(LLAssetType::EType asset_type,
 +							 LLInventoryType::EType inventory_type,
 +							 U32 attachment_point, 
 +							 BOOL item_is_multi );
 +
 +#endif // LL_LLINVENTORYFUNCTIONS_H
 +
 +
 +
 diff --git a/indra/newview/llinventorymodel.cpp b/indra/newview/llinventorymodel.cpp index 84588fbe8c..fbaab385fe 100644 --- a/indra/newview/llinventorymodel.cpp +++ b/indra/newview/llinventorymodel.cpp @@ -509,7 +509,7 @@ void LLInventoryModel::collectDescendentsIf(const LLUUID& id,  	}  } -void LLInventoryModel::updateLinkedItems(const LLUUID& object_id) +void LLInventoryModel::addChangedMaskForLinks(const LLUUID& object_id, U32 mask)  {  	const LLInventoryObject *obj = getObject(object_id);  	if (!obj || obj->getIsLinkType()) @@ -532,7 +532,7 @@ void LLInventoryModel::updateLinkedItems(const LLUUID& object_id)  		 cat_iter++)  	{  		LLViewerInventoryCategory *linked_cat = (*cat_iter); -		addChangedMask(LLInventoryObserver::LABEL, linked_cat->getUUID()); +		addChangedMask(mask, linked_cat->getUUID());  	};  	for (LLInventoryModel::item_array_t::iterator iter = item_array.begin(); @@ -540,9 +540,8 @@ void LLInventoryModel::updateLinkedItems(const LLUUID& object_id)  		 iter++)  	{  		LLViewerInventoryItem *linked_item = (*iter); -		addChangedMask(LLInventoryObserver::LABEL, linked_item->getUUID()); +		addChangedMask(mask, linked_item->getUUID());  	}; -	notifyObservers();  }  const LLUUID& LLInventoryModel::getLinkedItemID(const LLUUID& object_id) const @@ -1133,6 +1132,14 @@ void LLInventoryModel::notifyObservers(const std::string service_name)  		llwarns << "Call was made to notifyObservers within notifyObservers!" << llendl;  		return;  	} + +	if ((mModifyMask == LLInventoryObserver::NONE) && (service_name == "")) +	{ +		mModifyMask = LLInventoryObserver::NONE; +		mChangedItemIDs.clear(); +		return; +	} +  	mIsNotifyObservers = TRUE;  	for (observer_list_t::iterator iter = mObservers.begin();  		 iter != mObservers.end(); ) @@ -1180,7 +1187,7 @@ void LLInventoryModel::addChangedMask(U32 mask, const LLUUID& referent)  	// not sure what else might need to be accounted for this.  	if (mModifyMask & LLInventoryObserver::LABEL)  	{ -		updateLinkedItems(referent); +		addChangedMaskForLinks(referent, LLInventoryObserver::LABEL);  	}  } diff --git a/indra/newview/llinventorymodel.h b/indra/newview/llinventorymodel.h index aa4ffb392f..da12dbdf7f 100644 --- a/indra/newview/llinventorymodel.h +++ b/indra/newview/llinventorymodel.h @@ -167,8 +167,6 @@ public:  	// Assumes item_id is itself not a linked item.  	item_array_t collectLinkedItems(const LLUUID& item_id,  									const LLUUID& start_folder_id = LLUUID::null); -	// Updates all linked items pointing to this id. -	void updateLinkedItems(const LLUUID& object_id);  	// Get the inventoryID that this item points to, else just return item_id  	const LLUUID& getLinkedItemID(const LLUUID& object_id) const; @@ -440,6 +438,9 @@ protected:  	bool messageUpdateCore(LLMessageSystem* msg, bool do_accounting); +	// Updates all linked items pointing to this id. +	void addChangedMaskForLinks(const LLUUID& object_id, U32 mask); +  protected:  	cat_array_t* getUnlockedCatArray(const LLUUID& id);  	item_array_t* getUnlockedItemArray(const LLUUID& id); diff --git a/indra/newview/llinventorypanel.cpp b/indra/newview/llinventorypanel.cpp index 3a8b8bdf9e..99591dea57 100644 --- a/indra/newview/llinventorypanel.cpp +++ b/indra/newview/llinventorypanel.cpp @@ -36,8 +36,6 @@  #include "llinventorypanel.h"
 -// Seraph TODO: Remove unnecessary headers
 -
  #include "llagent.h"
  #include "llagentwearables.h"
  #include "llappearancemgr.h"
 @@ -56,6 +54,22 @@ const std::string LLInventoryPanel::RECENTITEMS_SORT_ORDER = std::string("Recent  const std::string LLInventoryPanel::INHERIT_SORT_ORDER = std::string("");
  static const LLInventoryFVBridgeBuilder INVENTORY_BRIDGE_BUILDER;
 +
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +// Class LLInventoryPanelObserver
 +//
 +// Bridge to support knowing when the inventory has changed.
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +class LLInventoryPanelObserver : public LLInventoryObserver
 +{
 +public:
 +	LLInventoryPanelObserver(LLInventoryPanel* ip) : mIP(ip) {}
 +	virtual ~LLInventoryPanelObserver() {}
 +	virtual void changed(U32 mask);
 +protected:
 +	LLInventoryPanel* mIP;
 +};
 +
  LLInventoryPanel::LLInventoryPanel(const LLInventoryPanel::Params& p) :	
  	LLPanel(p),
  	mInventoryObserver(NULL),
 @@ -131,27 +145,10 @@ BOOL LLInventoryPanel::postBuild()  	mInventoryObserver = new LLInventoryPanelObserver(this);
  	mInventory->addObserver(mInventoryObserver);
 -	// determine the root folder, if any, so inventory contents show just the children
 -	// of that folder (i.e. not including the folder itself).
 -	const LLFolderType::EType preferred_type = LLViewerFolderType::lookupTypeFromNewCategoryName(mStartFolderString);
 -
 -	if ("INVENTORY" == mStartFolderString)
 -	{
 -		mStartFolderID = gInventory.getRootFolderID();
 -	}
 -	else if ("LIBRARY" == mStartFolderString)
 -	{
 -		mStartFolderID = gInventory.getLibraryRootFolderID();
 -	}
 -	else
 -	{
 -		mStartFolderID = (preferred_type != LLFolderType::FT_NONE ? gInventory.findCategoryUUIDForType(preferred_type) : LLUUID::null);
 -	}
 -
  	// build view of inventory if we need default full hierarchy and inventory ready, otherwise wait for modelChanged() callback
  	if (mBuildDefaultHierarchy && mInventory->isInventoryUsable() && !mHasInventoryConnection)
  	{
 -		rebuildViewsFor(mStartFolderID);
 +		rebuildViews();
  		mHasInventoryConnection = true;
  		defaultOpenInventory();
  	}
 @@ -258,7 +255,7 @@ void LLInventoryPanel::modelChanged(U32 mask)  	// inventory just initialized, do complete build
  	if ((mask & LLInventoryObserver::ADD) && gInventory.getChangedIDs().empty() && !mHasInventoryConnection)
  	{
 -		rebuildViewsFor(mStartFolderID);
 +		rebuildViews();
  		mHasInventoryConnection = true;
  		defaultOpenInventory();
  		return;
 @@ -348,14 +345,6 @@ void LLInventoryPanel::modelChanged(U32 mask)  							view_item->destroyView();
  						}
  					}
 -					else
 -					{
 -						// Hmm, we got an ADD/REMOVE/STRUCTURE notification for this item but there's nothing to be done to it.
 -						llwarns << "Notification triggered for item that isn't changing.  "
 -								<< "Operation: ( mask: " << mask << " panel name: " << mStartFolderString << " ) "
 -								<< "Item: [ Name:" << model_item->getName() << " UUID: " << *id_it << " ]" << llendl;
 -						
 -					}
  				}
  				// This item has been removed from memory, but its associated UI element still exists.
 @@ -378,6 +367,24 @@ void LLInventoryPanel::modelChanged(U32 mask)  }
 +void LLInventoryPanel::rebuildViews()
 +{
 +	// Determine the root folder and rebuild the views starting
 +	// at that folder.
 +	const LLFolderType::EType preferred_type = LLViewerFolderType::lookupTypeFromNewCategoryName(mStartFolderString);
 +
 +	if ("LIBRARY" == mStartFolderString)
 +	{
 +		mStartFolderID = gInventory.getLibraryRootFolderID();
 +	}
 +	else
 +	{
 +		mStartFolderID = (preferred_type != LLFolderType::FT_NONE ? gInventory.findCategoryUUIDForType(preferred_type) : LLUUID::null);
 +	}
 +	
 +	rebuildViewsFor(mStartFolderID);
 +}
 +
  void LLInventoryPanel::rebuildViewsFor(const LLUUID& id)
  {
  	LLFolderViewItem* old_view = NULL;
 @@ -396,88 +403,86 @@ void LLInventoryPanel::buildNewViews(const LLUUID& id)  {
  	LLMemType mt(LLMemType::MTYPE_INVENTORY_BUILD_NEW_VIEWS);
  	LLFolderViewItem* itemp = NULL;
 -	LLInventoryObject* objectp = NULL;
 -
 -	// Don't add the start folder (the inventory panel will show contents
 -	// beginning with the children of the starting folder, excluding the starting folder itself).
 -	if (id != mStartFolderID)
 +	LLInventoryObject* objectp = gInventory.getObject(id);
 +	if (objectp)
  	{
 -		objectp = gInventory.getObject(id);
 -		if (objectp)
 -		{		
 -			const LLUUID &parent_id = objectp->getParentUUID();
 -			// If this item's parent is the starting folder, then just add it to the top level (recall that 
 -			// the starting folder isn't actually represented in the view, parent_folder would be NULL in
 -			// this case otherwise).
 -			LLFolderViewFolder* parent_folder = (parent_id == mStartFolderID ?
 -				mFolders : (LLFolderViewFolder*)mFolders->getItemByID(parent_id));
 -
 +		const LLUUID &parent_id = objectp->getParentUUID();
 +		LLFolderViewFolder* parent_folder = (LLFolderViewFolder*)mFolders->getItemByID(parent_id);
 +		if (id == mStartFolderID)
 +			parent_folder = mFolders;
 +		
 +		if (!parent_folder)
 +		{
  			// This item exists outside the inventory's hierarchy, so don't add it.
 -			if (!parent_folder)
 -			{
 -				return;
 -			}
 -
 -			if (objectp->getType() <= LLAssetType::AT_NONE ||
 -				objectp->getType() >= LLAssetType::AT_COUNT)
 -			{
 -				llwarns << "LLInventoryPanel::buildNewViews called with invalid objectp->mType : " << 
 -					((S32) objectp->getType()) << " name " << objectp->getName() << " UUID " << objectp->getUUID() << llendl;
 -				return;
 -			}
 +			return;
 +		}
 +		
 +		if (objectp->getType() <= LLAssetType::AT_NONE ||
 +			objectp->getType() >= LLAssetType::AT_COUNT)
 +		{
 +			llwarns << "LLInventoryPanel::buildNewViews called with invalid objectp->mType : " << 
 +				((S32) objectp->getType()) << " name " << objectp->getName() << " UUID " << objectp->getUUID() << llendl;
 +			return;
 +		}
 +		
 +		if (objectp->getType() == LLAssetType::AT_CATEGORY &&
 +			objectp->getActualType() != LLAssetType::AT_LINK_FOLDER) 
 +		{
 +			LLInvFVBridge* new_listener = mInvFVBridgeBuilder->createBridge(objectp->getType(),
 +																			objectp->getType(),
 +																			LLInventoryType::IT_CATEGORY,
 +																			this,
 +																			objectp->getUUID());
 -			if (objectp->getType() == LLAssetType::AT_CATEGORY &&
 -					 objectp->getActualType() != LLAssetType::AT_LINK_FOLDER) 
 +			if (new_listener)
  			{
 -				LLInvFVBridge* new_listener = mInvFVBridgeBuilder->createBridge(objectp->getType(),
 -																				objectp->getType(),
 -																				LLInventoryType::IT_CATEGORY,
 -																				this,
 -																				objectp->getUUID());
 -
 -				if (new_listener)
 +				LLFolderViewFolder::Params p;
 +				p.name = new_listener->getDisplayName();
 +				p.icon = new_listener->getIcon();
 +				p.root = mFolders;
 +				p.listener = new_listener;
 +				p.tool_tip = p.name;
 +				LLFolderViewFolder* folderp = LLUICtrlFactory::create<LLFolderViewFolder>(p);
 +				folderp->setItemSortOrder(mFolders->getSortOrder());
 +				itemp = folderp;
 +
 +				// Hide the root folder, so we can show the contents of a folder
 +				// flat but still have the parent folder present for listener-related
 +				// operations.
 +				if (id == mStartFolderID)
  				{
 -					LLFolderViewFolder::Params p;
 -					p.name = new_listener->getDisplayName();
 -					p.icon = new_listener->getIcon();
 -					p.root = mFolders;
 -					p.listener = new_listener;
 -					p.tool_tip = p.name;
 -					LLFolderViewFolder* folderp = LLUICtrlFactory::create<LLFolderViewFolder>(p);
 -				
 -					folderp->setItemSortOrder(mFolders->getSortOrder());
 -					itemp = folderp;
 +					folderp->setDontShowInHierarchy(TRUE);
  				}
  			}
 -			else 
 +		}
 +		else 
 +		{
 +			// Build new view for item
 +			LLInventoryItem* item = (LLInventoryItem*)objectp;
 +			LLInvFVBridge* new_listener = mInvFVBridgeBuilder->createBridge(item->getType(),
 +																			item->getActualType(),
 +																			item->getInventoryType(),
 +																			this,
 +																			item->getUUID(),
 +																			item->getFlags());
 +
 +			if (new_listener)
  			{
 -				// Build new view for item
 -				LLInventoryItem* item = (LLInventoryItem*)objectp;
 -				LLInvFVBridge* new_listener = mInvFVBridgeBuilder->createBridge(item->getType(),
 -																				item->getActualType(),
 -																				item->getInventoryType(),
 -																				this,
 -																				item->getUUID(),
 -																				item->getFlags());
 -
 -				if (new_listener)
 -				{
 -					LLFolderViewItem::Params params;
 -					params.name(new_listener->getDisplayName());
 -					params.icon(new_listener->getIcon());
 -					params.creation_date(new_listener->getCreationDate());
 -					params.root(mFolders);
 -					params.listener(new_listener);
 -					params.rect(LLRect (0, 0, 0, 0));
 -					params.tool_tip = params.name;
 -					itemp = LLUICtrlFactory::create<LLFolderViewItem> (params);
 -				}
 +				LLFolderViewItem::Params params;
 +				params.name(new_listener->getDisplayName());
 +				params.icon(new_listener->getIcon());
 +				params.creation_date(new_listener->getCreationDate());
 +				params.root(mFolders);
 +				params.listener(new_listener);
 +				params.rect(LLRect (0, 0, 0, 0));
 +				params.tool_tip = params.name;
 +				itemp = LLUICtrlFactory::create<LLFolderViewItem> (params);
  			}
 +		}
 -			if (itemp)
 -			{
 -				itemp->addToFolder(parent_folder, mFolders);
 -			}
 +		if (itemp)
 +		{
 +			itemp->addToFolder(parent_folder, mFolders);
  		}
  	}
 @@ -875,3 +880,11 @@ void example_param_block_usage()  	LLUICtrlFactory::create<LLInventoryPanel>(param_block);
  }
 +
 +// +=================================================+
 +// |        LLInventoryPanelObserver                 |
 +// +=================================================+
 +void LLInventoryPanelObserver::changed(U32 mask)
 +{
 +	mIP->modelChanged(mask);
 +}
 diff --git a/indra/newview/llinventorypanel.h b/indra/newview/llinventorypanel.h index e398c44105..0ccee337c9 100644 --- a/indra/newview/llinventorypanel.h +++ b/indra/newview/llinventorypanel.h @@ -162,6 +162,10 @@ public:  	void unSelectAll()	{ mFolders->setSelection(NULL, FALSE, FALSE); }  protected: +	// Destroys the old views, and regenerates them based on the +	// start folder ID. +	void rebuildViews(); +  	// Given the id and the parent, build all of the folder views.  	void rebuildViewsFor(const LLUUID& id);  	virtual void buildNewViews(const LLUUID& id); // made virtual to support derived classes. EXT-719 diff --git a/indra/newview/llnavigationbar.cpp b/indra/newview/llnavigationbar.cpp index 794d73a5ad..0c2782fd8a 100644 --- a/indra/newview/llnavigationbar.cpp +++ b/indra/newview/llnavigationbar.cpp @@ -217,7 +217,7 @@ BOOL LLNavigationBar::postBuild()  	mBtnHome->setClickedCallback(boost::bind(&LLNavigationBar::onHomeButtonClicked, this)); -	mCmbLocation->setSelectionCallback(boost::bind(&LLNavigationBar::onLocationSelection, this)); +	mCmbLocation->setCommitCallback(boost::bind(&LLNavigationBar::onLocationSelection, this));  	mSearchComboBox->setCommitCallback(boost::bind(&LLNavigationBar::onSearchCommit, this)); diff --git a/indra/newview/llpanellandmarks.cpp b/indra/newview/llpanellandmarks.cpp index ce1a7f98df..e199db37ab 100644 --- a/indra/newview/llpanellandmarks.cpp +++ b/indra/newview/llpanellandmarks.cpp @@ -97,10 +97,10 @@ BOOL LLLandmarksPanel::postBuild()  	U32 sort_order = gSavedSettings.getU32(LLInventoryPanel::DEFAULT_SORT_ORDER);  	mSortByDate = sort_order & LLInventoryFilter::SO_DATE; -	initFavoritesInventroyPanel(); -	initLandmarksInventroyPanel(); -	initMyInventroyPanel(); -	initLibraryInventroyPanel(); +	initFavoritesInventoryPanel(); +	initLandmarksInventoryPanel(); +	initMyInventoryPanel(); +	initLibraryInventoryPanel();  	getChild<LLAccordionCtrlTab>("tab_favorites")->setDisplayChildren(true);  	getChild<LLAccordionCtrlTab>("tab_landmarks")->setDisplayChildren(true); @@ -357,7 +357,7 @@ void LLLandmarksPanel::setErrorStatus(U32 status, const std::string& reason)  // PRIVATE METHODS  ////////////////////////////////////////////////////////////////////////// -void LLLandmarksPanel::initFavoritesInventroyPanel() +void LLLandmarksPanel::initFavoritesInventoryPanel()  {  	mFavoritesInventoryPanel = getChild<LLInventorySubTreePanel>("favorites_list"); @@ -366,7 +366,7 @@ void LLLandmarksPanel::initFavoritesInventroyPanel()  	initAccordion("tab_favorites", mFavoritesInventoryPanel);  } -void LLLandmarksPanel::initLandmarksInventroyPanel() +void LLLandmarksPanel::initLandmarksInventoryPanel()  {  	mLandmarksInventoryPanel = getChild<LLInventorySubTreePanel>("landmarks_list"); @@ -380,7 +380,7 @@ void LLLandmarksPanel::initLandmarksInventroyPanel()  	initAccordion("tab_landmarks", mLandmarksInventoryPanel);  } -void LLLandmarksPanel::initMyInventroyPanel() +void LLLandmarksPanel::initMyInventoryPanel()  {  	mMyInventoryPanel= getChild<LLInventorySubTreePanel>("my_inventory_list"); @@ -389,7 +389,7 @@ void LLLandmarksPanel::initMyInventroyPanel()  	initAccordion("tab_inventory", mMyInventoryPanel);  } -void LLLandmarksPanel::initLibraryInventroyPanel() +void LLLandmarksPanel::initLibraryInventoryPanel()  {  	mLibraryInventoryPanel = getChild<LLInventorySubTreePanel>("library_list"); diff --git a/indra/newview/llpanellandmarks.h b/indra/newview/llpanellandmarks.h index 745f9364c2..097d79badf 100644 --- a/indra/newview/llpanellandmarks.h +++ b/indra/newview/llpanellandmarks.h @@ -78,10 +78,10 @@ protected:  	/*virtual*/ void setErrorStatus(U32 status, const std::string& reason);  private: -	void initFavoritesInventroyPanel(); -	void initLandmarksInventroyPanel(); -	void initMyInventroyPanel(); -	void initLibraryInventroyPanel(); +	void initFavoritesInventoryPanel(); +	void initLandmarksInventoryPanel(); +	void initMyInventoryPanel(); +	void initLibraryInventoryPanel();  	void initLandmarksPanel(LLInventorySubTreePanel* inventory_list);  	void initAccordion(const std::string& accordion_tab_name, LLInventorySubTreePanel* inventory_list);  	void onAccordionExpandedCollapsed(const LLSD& param, LLInventorySubTreePanel* inventory_list); diff --git a/indra/newview/llpanelmaininventory.cpp b/indra/newview/llpanelmaininventory.cpp index e3b2ab77aa..9f723169e1 100644 --- a/indra/newview/llpanelmaininventory.cpp +++ b/indra/newview/llpanelmaininventory.cpp @@ -49,7 +49,7 @@  #include "llviewermenu.h"
  #include "llviewertexturelist.h"
 -static LLRegisterPanelClassWrapper<LLPanelMainInventory> t_inventory("panel_main_inventory"); // Seraph is this redundant with constructor?
 +static LLRegisterPanelClassWrapper<LLPanelMainInventory> t_inventory("panel_main_inventory");
  void on_file_loaded_for_save(BOOL success, 
  							 LLViewerFetchedTexture *src_vi,
 @@ -197,28 +197,6 @@ BOOL LLPanelMainInventory::postBuild()  	return TRUE;
  }
 -void LLPanelMainInventory::initListCommandsHandlers()
 -{
 -	mListCommands = getChild<LLPanel>("bottom_panel");
 -
 -	mListCommands->childSetAction("options_gear_btn", boost::bind(&LLPanelMainInventory::onGearButtonClick, this));
 -	mListCommands->childSetAction("trash_btn", boost::bind(&LLPanelMainInventory::onTrashButtonClick, this));
 -	mListCommands->childSetAction("add_btn", boost::bind(&LLPanelMainInventory::onAddButtonClick, this));
 -
 -	LLDragAndDropButton* trash_btn = mListCommands->getChild<LLDragAndDropButton>("trash_btn");
 -	trash_btn->setDragAndDropHandler(boost::bind(&LLPanelMainInventory::handleDragAndDropToTrash, this
 -			,	_4 // BOOL drop
 -			,	_5 // EDragAndDropType cargo_type
 -			,	_7 // EAcceptance* accept
 -			));
 -
 -	mCommitCallbackRegistrar.add("Inventory.GearDefault.Custom.Action", boost::bind(&LLPanelMainInventory::onCustomAction, this, _2));
 -	mEnableCallbackRegistrar.add("Inventory.GearDefault.Enable", boost::bind(&LLPanelMainInventory::isActionEnabled, this, _2));
 -	mMenuGearDefault = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>("menu_inventory_gear_default.xml", gMenuHolder, LLViewerMenuHolderGL::child_registry_t::instance());
 -	mMenuAdd = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>("menu_inventory_add.xml", gMenuHolder, LLViewerMenuHolderGL::child_registry_t::instance());
 -	
 -}
 -
  // Destroys the object
  LLPanelMainInventory::~LLPanelMainInventory( void )
  {
 @@ -863,9 +841,30 @@ void LLFloaterInventoryFinder::selectNoTypes(void* user_data)  	self->childSetValue("check_snapshot", FALSE);
  }
 +//////////////////////////////////////////////////////////////////////////////////
 +// List Commands                                                                //
 +void LLPanelMainInventory::initListCommandsHandlers()
 +{
 +	mListCommands = getChild<LLPanel>("bottom_panel");
 +	mListCommands->childSetAction("options_gear_btn", boost::bind(&LLPanelMainInventory::onGearButtonClick, this));
 +	mListCommands->childSetAction("trash_btn", boost::bind(&LLPanelMainInventory::onTrashButtonClick, this));
 +	mListCommands->childSetAction("add_btn", boost::bind(&LLPanelMainInventory::onAddButtonClick, this));
 +	LLDragAndDropButton* trash_btn = mListCommands->getChild<LLDragAndDropButton>("trash_btn");
 +	trash_btn->setDragAndDropHandler(boost::bind(&LLPanelMainInventory::handleDragAndDropToTrash, this
 +			,	_4 // BOOL drop
 +			,	_5 // EDragAndDropType cargo_type
 +			,	_7 // EAcceptance* accept
 +			));
 +
 +	mCommitCallbackRegistrar.add("Inventory.GearDefault.Custom.Action", boost::bind(&LLPanelMainInventory::onCustomAction, this, _2));
 +	mEnableCallbackRegistrar.add("Inventory.GearDefault.Enable", boost::bind(&LLPanelMainInventory::isActionEnabled, this, _2));
 +	mMenuGearDefault = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>("menu_inventory_gear_default.xml", gMenuHolder, LLViewerMenuHolderGL::child_registry_t::instance());
 +	mMenuAdd = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>("menu_inventory_add.xml", gMenuHolder, LLViewerMenuHolderGL::child_registry_t::instance());
 +	
 +}
  void LLPanelMainInventory::updateListCommands()
  {
 @@ -1018,3 +1017,6 @@ bool LLPanelMainInventory::handleDragAndDropToTrash(BOOL drop, EDragAndDropType  	}
  	return true;
  }
 +
 +// List Commands                                                              //
 +////////////////////////////////////////////////////////////////////////////////
 diff --git a/indra/newview/llpanelmaininventory.h b/indra/newview/llpanelmaininventory.h index fbc0f09c50..627be21577 100644 --- a/indra/newview/llpanelmaininventory.h +++ b/indra/newview/llpanelmaininventory.h @@ -111,7 +111,20 @@ protected:  	void resetFilters();
  	void setSortBy(const LLSD& userdata);
 -	// List Commands Handlers
 +private:
 +	LLFloaterInventoryFinder* getFinder();
 +
 +	LLFilterEditor*				mFilterEditor;
 +	LLTabContainer*				mFilterTabs;
 +	LLHandle<LLFloater>			mFinderHandle;
 +	LLInventoryPanel*			mActivePanel;
 +	LLSaveFolderState*			mSavedFolderState;
 +	std::string					mFilterText;
 +
 +
 +	//////////////////////////////////////////////////////////////////////////////////
 +	// List Commands                                                                //
 +protected:
  	void initListCommandsHandlers();
  	void updateListCommands();
  	void onGearButtonClick();
 @@ -122,22 +135,12 @@ protected:  	BOOL isActionEnabled(const LLSD& command_name);
  	void onCustomAction(const LLSD& command_name);
  	bool handleDragAndDropToTrash(BOOL drop, EDragAndDropType cargo_type, EAcceptance* accept);
 -
 -
  private:
 -	LLFloaterInventoryFinder* getFinder();
 -
 -	LLFilterEditor*				mFilterEditor;
 -	LLTabContainer*				mFilterTabs;
 -	LLHandle<LLFloater>			mFinderHandle;
 -	LLInventoryPanel*			mActivePanel;
 -	LLSaveFolderState*			mSavedFolderState;
 -
  	LLPanel*					mListCommands;
  	LLMenuGL*					mMenuGearDefault;
  	LLMenuGL*					mMenuAdd;
 -
 -	std::string					mFilterText;
 +	// List Commands                                                              //
 +	////////////////////////////////////////////////////////////////////////////////
  };
  #endif // LL_LLPANELMAININVENTORY_H
 diff --git a/indra/newview/llpanelobjectinventory.h b/indra/newview/llpanelobjectinventory.h index 6722bb212e..7a39d8fabc 100644 --- a/indra/newview/llpanelobjectinventory.h +++ b/indra/newview/llpanelobjectinventory.h @@ -1,102 +1,102 @@ -/**  - * @file llpanelobjectinventory.h - * @brief LLPanelObjectInventory class definition - * - * $LicenseInfo:firstyear=2002&license=viewergpl$ - *  - * Copyright (c) 2002-2009, Linden Research, Inc. - *  - * Second Life Viewer Source Code - * The source code in this file ("Source Code") is provided by Linden Lab - * to you under the terms of the GNU General Public License, version 2.0 - * ("GPL"), unless you have obtained a separate licensing agreement - * ("Other License"), formally executed by you and Linden Lab.  Terms of - * the GPL can be found in doc/GPL-license.txt in this distribution, or - * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 - *  - * There are special exceptions to the terms and conditions of the GPL as - * it is applied to this Source Code. View the full text of the exception - * in the file doc/FLOSS-exception.txt in this software distribution, or - * online at - * http://secondlifegrid.net/programs/open_source/licensing/flossexception - *  - * By copying, modifying or distributing this software, you acknowledge - * that you have read and understood your obligations described above, - * and agree to abide by those obligations. - *  - * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO - * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, - * COMPLETENESS OR PERFORMANCE. - * $/LicenseInfo$ - */ - -#ifndef LL_LLPANELOBJECTINVENTORY_H -#define LL_LLPANELOBJECTINVENTORY_H - -#include "llvoinventorylistener.h" -#include "llpanel.h" - -#include "llinventory.h" - -class LLScrollContainer; -class LLFolderView; -class LLFolderViewFolder; -class LLViewerObject; - -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -// Class LLPanelObjectInventory -// -// This class represents the panel used to view and control a -// particular task's inventory. -// -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -class LLPanelObjectInventory : public LLPanel, public LLVOInventoryListener -{ -public: -	// dummy param block for template registration purposes -	struct Params : public LLPanel::Params {}; - -	LLPanelObjectInventory(const Params&); -	virtual ~LLPanelObjectInventory(); -	 -	virtual BOOL postBuild(); - -	void doToSelected(const LLSD& userdata); -	 -	void refresh(); -	const LLUUID& getTaskUUID() { return mTaskUUID;} -	void removeSelectedItem(); -	void startRenamingSelectedItem(); - -	LLFolderView* getRootFolder() const { return mFolders; } - -	virtual void draw(); -	virtual void deleteAllChildren(); -	virtual BOOL handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, EDragAndDropType cargo_type, void *cargo_data, EAcceptance *accept, std::string& tooltip_msg); -	 -	static void idle(void* user_data); - -protected: -	void reset(); -	/*virtual*/ void inventoryChanged(LLViewerObject* object, -								 InventoryObjectList* inventory, -								 S32 serial_num, -								 void* user_data); -	void updateInventory(); -	void createFolderViews(LLInventoryObject* inventory_root, InventoryObjectList& contents); -	void createViewsForCategory(InventoryObjectList* inventory, -								LLInventoryObject* parent, -								LLFolderViewFolder* folder); -	void clearContents(); - -private: -	LLScrollContainer* mScroller; -	LLFolderView* mFolders; -	 -	LLUUID mTaskUUID; -	BOOL mHaveInventory; -	BOOL mIsInventoryEmpty; -	BOOL mInventoryNeedsUpdate; -}; - -#endif // LL_LLPANELOBJECTINVENTORY_H +/** 
 + * @file llpanelobjectinventory.h
 + * @brief LLPanelObjectInventory class definition
 + *
 + * $LicenseInfo:firstyear=2002&license=viewergpl$
 + * 
 + * Copyright (c) 2002-2009, Linden Research, Inc.
 + * 
 + * Second Life Viewer Source Code
 + * The source code in this file ("Source Code") is provided by Linden Lab
 + * to you under the terms of the GNU General Public License, version 2.0
 + * ("GPL"), unless you have obtained a separate licensing agreement
 + * ("Other License"), formally executed by you and Linden Lab.  Terms of
 + * the GPL can be found in doc/GPL-license.txt in this distribution, or
 + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
 + * 
 + * There are special exceptions to the terms and conditions of the GPL as
 + * it is applied to this Source Code. View the full text of the exception
 + * in the file doc/FLOSS-exception.txt in this software distribution, or
 + * online at
 + * http://secondlifegrid.net/programs/open_source/licensing/flossexception
 + * 
 + * By copying, modifying or distributing this software, you acknowledge
 + * that you have read and understood your obligations described above,
 + * and agree to abide by those obligations.
 + * 
 + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
 + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
 + * COMPLETENESS OR PERFORMANCE.
 + * $/LicenseInfo$
 + */
 +
 +#ifndef LL_LLPANELOBJECTINVENTORY_H
 +#define LL_LLPANELOBJECTINVENTORY_H
 +
 +#include "llvoinventorylistener.h"
 +#include "llpanel.h"
 +
 +#include "llinventory.h"
 +
 +class LLScrollContainer;
 +class LLFolderView;
 +class LLFolderViewFolder;
 +class LLViewerObject;
 +
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +// Class LLPanelObjectInventory
 +//
 +// This class represents the panel used to view and control a
 +// particular task's inventory.
 +//
 +//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
 +class LLPanelObjectInventory : public LLPanel, public LLVOInventoryListener
 +{
 +public:
 +	// dummy param block for template registration purposes
 +	struct Params : public LLPanel::Params {};
 +
 +	LLPanelObjectInventory(const Params&);
 +	virtual ~LLPanelObjectInventory();
 +	
 +	virtual BOOL postBuild();
 +
 +	void doToSelected(const LLSD& userdata);
 +	
 +	void refresh();
 +	const LLUUID& getTaskUUID() { return mTaskUUID;}
 +	void removeSelectedItem();
 +	void startRenamingSelectedItem();
 +
 +	LLFolderView* getRootFolder() const { return mFolders; }
 +
 +	virtual void draw();
 +	virtual void deleteAllChildren();
 +	virtual BOOL handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, EDragAndDropType cargo_type, void *cargo_data, EAcceptance *accept, std::string& tooltip_msg);
 +	
 +	static void idle(void* user_data);
 +
 +protected:
 +	void reset();
 +	/*virtual*/ void inventoryChanged(LLViewerObject* object,
 +								 InventoryObjectList* inventory,
 +								 S32 serial_num,
 +								 void* user_data);
 +	void updateInventory();
 +	void createFolderViews(LLInventoryObject* inventory_root, InventoryObjectList& contents);
 +	void createViewsForCategory(InventoryObjectList* inventory,
 +								LLInventoryObject* parent,
 +								LLFolderViewFolder* folder);
 +	void clearContents();
 +
 +private:
 +	LLScrollContainer* mScroller;
 +	LLFolderView* mFolders;
 +	
 +	LLUUID mTaskUUID;
 +	BOOL mHaveInventory;
 +	BOOL mIsInventoryEmpty;
 +	BOOL mInventoryNeedsUpdate;
 +};
 +
 +#endif // LL_LLPANELOBJECTINVENTORY_H
 diff --git a/indra/newview/llpaneloutfitsinventory.cpp b/indra/newview/llpaneloutfitsinventory.cpp new file mode 100644 index 0000000000..5ad9bf056e --- /dev/null +++ b/indra/newview/llpaneloutfitsinventory.cpp @@ -0,0 +1,347 @@ +/** + * @file llpaneloutfitsinventory.cpp + * @brief Outfits inventory panel + * + * $LicenseInfo:firstyear=2009&license=viewergpl$ + * + * Copyright (c) 2001-2009, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab.  Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#include "llviewerprecompiledheaders.h" + +#include "llpaneloutfitsinventory.h" + +#include "llagent.h" +#include "llagentwearables.h" + +#include "llbutton.h" +#include "llfloaterreg.h" +#include "llfloaterworldmap.h" +#include "llfloaterinventory.h" +#include "llfoldervieweventlistener.h" +#include "llinventoryfunctions.h" +#include "llinventorypanel.h" +#include "lllandmark.h" +#include "llsidepanelappearance.h" +#include "llsidetray.h" +#include "lltabcontainer.h" +#include "llviewerfoldertype.h" +#include "llviewerjointattachment.h" +#include "llvoavatarself.h" + +// List Commands +#include "lldndbutton.h" +#include "llmenugl.h" +#include "llviewermenu.h" + +static LLRegisterPanelClassWrapper<LLPanelOutfitsInventory> t_inventory("panel_outfits_inventory"); + +LLPanelOutfitsInventory::LLPanelOutfitsInventory() : +	mInventoryPanel(NULL), +	mParent(NULL) +{ +	mSavedFolderState = new LLSaveFolderState(); +	mSavedFolderState->setApply(FALSE); +} + +LLPanelOutfitsInventory::~LLPanelOutfitsInventory() +{ +	delete mSavedFolderState; +} + +// virtual +BOOL LLPanelOutfitsInventory::postBuild() +{ +	mInventoryPanel = getChild<LLInventoryPanel>("outfits_list"); +	mInventoryPanel->setFilterTypes(1LL << LLFolderType::FT_OUTFIT, TRUE); +	mInventoryPanel->setShowFolderState(LLInventoryFilter::SHOW_NON_EMPTY_FOLDERS); +	mInventoryPanel->openDefaultFolderForType(LLFolderType::FT_MY_OUTFITS); +	mInventoryPanel->setSelectCallback(boost::bind(&LLPanelOutfitsInventory::onSelectionChange, this, _1, _2)); +	 +	initListCommandsHandlers(); +	return TRUE; +} + +void LLPanelOutfitsInventory::updateParent() +{ +	if (mParent) +	{ +		mParent->updateVerbs(); +	} +} + +void LLPanelOutfitsInventory::setParent(LLSidepanelAppearance* parent) +{ +	mParent = parent; +} + +// virtual +void LLPanelOutfitsInventory::onSearchEdit(const std::string& string) +{ +	if (string == "") +	{ +		mInventoryPanel->setFilterSubString(LLStringUtil::null); + +		// re-open folders that were initially open +		mSavedFolderState->setApply(TRUE); +		getRootFolder()->applyFunctorRecursively(*mSavedFolderState); +		LLOpenFoldersWithSelection opener; +		getRootFolder()->applyFunctorRecursively(opener); +		getRootFolder()->scrollToShowSelection(); +	} + +	gInventory.startBackgroundFetch(); + +	if (mInventoryPanel->getFilterSubString().empty() && string.empty()) +	{ +		// current filter and new filter empty, do nothing +		return; +	} + +	// save current folder open state if no filter currently applied +	if (getRootFolder()->getFilterSubString().empty()) +	{ +		mSavedFolderState->setApply(FALSE); +		getRootFolder()->applyFunctorRecursively(*mSavedFolderState); +	} + +	// set new filter string +	mInventoryPanel->setFilterSubString(string); +} + +void LLPanelOutfitsInventory::onWear() +{ +	LLFolderViewEventListener* listenerp = getCorrectListenerForAction(); +	if (listenerp) +	{ +		listenerp->performAction(NULL, NULL,"replaceoutfit"); +	} +} + +void LLPanelOutfitsInventory::onEdit() +{ +} + +void LLPanelOutfitsInventory::onNew() +{ +	const std::string& outfit_name = LLViewerFolderType::lookupNewCategoryName(LLFolderType::FT_OUTFIT); +	LLUUID outfit_folder = gAgentWearables.makeNewOutfitLinks(outfit_name); +	getRootFolder()->setSelectionByID(outfit_folder, TRUE); +	getRootFolder()->setNeedsAutoRename(TRUE); +} + +void LLPanelOutfitsInventory::onSelectionChange(const std::deque<LLFolderViewItem*> &items, BOOL user_action) +{ +	updateParent(); +} + +void LLPanelOutfitsInventory::onSelectorButtonClicked() +{ +	/* +	  LLFolderViewItem* cur_item = getRootFolder()->getCurSelectedItem(); + +	  LLFolderViewEventListener* listenerp = cur_item->getListener(); +	  if (getIsCorrectType(listenerp)) +	  { +	  LLSD key; +	  key["type"] = "look"; +	  key["id"] = listenerp->getUUID(); + +	  LLSideTray::getInstance()->showPanel("sidepanel_appearance", key); +	  }  +	*/ +} + +LLFolderViewEventListener *LLPanelOutfitsInventory::getCorrectListenerForAction() +{ +	LLFolderViewItem* current_item = getRootFolder()->getCurSelectedItem(); +	if (!current_item) +		return NULL; + +	LLFolderViewEventListener* listenerp = current_item->getListener(); +	if (getIsCorrectType(listenerp)) +	{ +		return listenerp; +	} +	return NULL; +} + +bool LLPanelOutfitsInventory::getIsCorrectType(const LLFolderViewEventListener *listenerp) const +{ +	if (listenerp->getInventoryType() == LLInventoryType::IT_CATEGORY) +	{ +		LLViewerInventoryCategory *cat = gInventory.getCategory(listenerp->getUUID()); +		if (cat && cat->getPreferredType() == LLFolderType::FT_OUTFIT) +		{ +			return true; +		} +	} +	return false; +} + +LLFolderView *LLPanelOutfitsInventory::getRootFolder() +{ +	return mInventoryPanel->getRootFolder(); +} + +////////////////////////////////////////////////////////////////////////////////// +// List Commands                                                                // + +void LLPanelOutfitsInventory::initListCommandsHandlers() +{ +	mListCommands = getChild<LLPanel>("bottom_panel"); + +	mListCommands->childSetAction("options_gear_btn", boost::bind(&LLPanelOutfitsInventory::onGearButtonClick, this)); +	mListCommands->childSetAction("trash_btn", boost::bind(&LLPanelOutfitsInventory::onTrashButtonClick, this)); +	mListCommands->childSetAction("add_btn", boost::bind(&LLPanelOutfitsInventory::onAddButtonClick, this)); + +	LLDragAndDropButton* trash_btn = mListCommands->getChild<LLDragAndDropButton>("trash_btn"); +	trash_btn->setDragAndDropHandler(boost::bind(&LLPanelOutfitsInventory::handleDragAndDropToTrash, this +			,	_4 // BOOL drop +			,	_5 // EDragAndDropType cargo_type +			,	_7 // EAcceptance* accept +			)); + +	mCommitCallbackRegistrar.add("panel_outfits_inventory_gear_default.Custom.Action", boost::bind(&LLPanelOutfitsInventory::onCustomAction, this, _2)); +	mEnableCallbackRegistrar.add("panel_outfits_inventory_gear_default.Enable", boost::bind(&LLPanelOutfitsInventory::isActionEnabled, this, _2)); +	mMenuGearDefault = LLUICtrlFactory::getInstance()->createFromFile<LLMenuGL>("panel_outfits_inventory_gear_default.xml", gMenuHolder, LLViewerMenuHolderGL::child_registry_t::instance()); +} + +void LLPanelOutfitsInventory::updateListCommands() +{ +	bool trash_enabled = isActionEnabled("delete"); + +	mListCommands->childSetEnabled("trash_btn", trash_enabled); +} + +void LLPanelOutfitsInventory::onGearButtonClick() +{ +	showActionMenu(mMenuGearDefault,"options_gear_btn"); +} + +void LLPanelOutfitsInventory::onAddButtonClick() +{ +	onNew(); +} + +void LLPanelOutfitsInventory::showActionMenu(LLMenuGL* menu, std::string spawning_view_name) +{ +	if (menu) +	{ +		menu->buildDrawLabels(); +		menu->updateParent(LLMenuGL::sMenuContainer); +		LLView* spawning_view = getChild<LLView> (spawning_view_name); +		S32 menu_x, menu_y; +		//show menu in co-ordinates of panel +		spawning_view->localPointToOtherView(0, spawning_view->getRect().getHeight(), &menu_x, &menu_y, this); +		menu_y += menu->getRect().getHeight(); +		LLMenuGL::showPopup(this, menu, menu_x, menu_y); +	} +} + +void LLPanelOutfitsInventory::onTrashButtonClick() +{ +	onClipboardAction("delete"); +} + +void LLPanelOutfitsInventory::onClipboardAction(const LLSD& userdata) +{ +	std::string command_name = userdata.asString(); +	getActivePanel()->getRootFolder()->doToSelected(getActivePanel()->getModel(),command_name); +} + +void LLPanelOutfitsInventory::onCustomAction(const LLSD& userdata) +{ +	if (!isActionEnabled(userdata)) +		return; + +	const std::string command_name = userdata.asString(); +	if (command_name == "new") +	{ +		onNew(); +	} +	if (command_name == "edit") +	{ +		onEdit(); +	} +	if (command_name == "wear") +	{ +		onWear(); +	} +	if (command_name == "delete") +	{ +		onClipboardAction("delete"); +	} +} + +BOOL LLPanelOutfitsInventory::isActionEnabled(const LLSD& userdata) +{ +	const std::string command_name = userdata.asString(); +	if (command_name == "delete") +	{ +		BOOL can_delete = FALSE; +		LLFolderView *folder = getActivePanel()->getRootFolder(); +		if (folder) +		{ +			can_delete = TRUE; +			std::set<LLUUID> selection_set; +			folder->getSelectionList(selection_set); +			for (std::set<LLUUID>::iterator iter = selection_set.begin(); +				 iter != selection_set.end(); +				 ++iter) +			{ +				const LLUUID &item_id = (*iter); +				LLFolderViewItem *item = folder->getItemByID(item_id); +				can_delete &= item->getListener()->isItemRemovable(); +			} +			return can_delete; +		} +		return FALSE; +	} +	if (command_name == "edit" ||  +		command_name == "wear") +	{ +		return (getCorrectListenerForAction() != NULL); +	} +	return TRUE; +} + +bool LLPanelOutfitsInventory::handleDragAndDropToTrash(BOOL drop, EDragAndDropType cargo_type, EAcceptance* accept) +{ +	*accept = ACCEPT_NO; + +	const bool is_enabled = isActionEnabled("delete"); +	if (is_enabled) *accept = ACCEPT_YES_MULTI; + +	if (is_enabled && drop) +	{ +		onClipboardAction("delete"); +	} +	return true; +} + +// List Commands                                                              // +//////////////////////////////////////////////////////////////////////////////// + diff --git a/indra/newview/llpaneloutfitsinventory.h b/indra/newview/llpaneloutfitsinventory.h new file mode 100644 index 0000000000..4d903a389b --- /dev/null +++ b/indra/newview/llpaneloutfitsinventory.h @@ -0,0 +1,102 @@ +/** + * @file llpaneloutfitsinventory.h + * @brief Outfits inventory panel + * class definition + * + * $LicenseInfo:firstyear=2009&license=viewergpl$ + * + * Copyright (c) 2001-2009, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab.  Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#ifndef LL_LLPANELOUTFITSINVENTORY_H +#define LL_LLPANELOUTFITSINVENTORY_H + +#include "llpanel.h" +#include "llinventoryobserver.h" + +class LLFolderView; +class LLFolderViewItem; +class LLFolderViewEventListener; +class LLInventoryPanel; +class LLSaveFolderState; +class LLButton; +class LLMenuGL; +class LLSidepanelAppearance; + +class LLPanelOutfitsInventory : public LLPanel +{ +public: +	LLPanelOutfitsInventory(); +	virtual ~LLPanelOutfitsInventory(); + +	/*virtual*/ BOOL postBuild(); +	 +	void onSearchEdit(const std::string& string); +	void onWear(); +	void onEdit(); +	void onNew(); + +	void onSelectionChange(const std::deque<LLFolderViewItem*> &items, BOOL user_action); +	void onSelectorButtonClicked(); + +	LLInventoryPanel* getActivePanel() { return mInventoryPanel; } + +	// If a compatible listener type is selected, then return a pointer to that. +	// Otherwise, return NULL. +	LLFolderViewEventListener* getCorrectListenerForAction(); +	void setParent(LLSidepanelAppearance *parent); +protected: +	void updateParent(); +	bool getIsCorrectType(const LLFolderViewEventListener *listenerp) const; +	LLFolderView* getRootFolder(); + +private: +	LLSidepanelAppearance*      mParent; +	LLInventoryPanel*			mInventoryPanel; +	LLSaveFolderState*			mSavedFolderState; + + +	////////////////////////////////////////////////////////////////////////////////// +	// List Commands                                                                // +protected: +	void initListCommandsHandlers(); +	void updateListCommands(); +	void onGearButtonClick(); +	void onAddButtonClick(); +	void showActionMenu(LLMenuGL* menu, std::string spawning_view_name); +	void onTrashButtonClick(); +	void onClipboardAction(const LLSD& userdata); +	BOOL isActionEnabled(const LLSD& command_name); +	void onCustomAction(const LLSD& command_name); +	bool handleDragAndDropToTrash(BOOL drop, EDragAndDropType cargo_type, EAcceptance* accept); +private: +	LLPanel*					mListCommands; +	LLMenuGL*					mMenuGearDefault; +	LLMenuGL*					mMenuAdd; +	//                                                                            // +	//////////////////////////////////////////////////////////////////////////////// +}; + +#endif //LL_LLPANELOUTFITSINVENTORY_H diff --git a/indra/newview/llpanelplaces.cpp b/indra/newview/llpanelplaces.cpp index 84232f20d1..257a21ca15 100644 --- a/indra/newview/llpanelplaces.cpp +++ b/indra/newview/llpanelplaces.cpp @@ -222,7 +222,7 @@ BOOL LLPanelPlaces::postBuild()  	notes_editor->setKeystrokeCallback(boost::bind(&LLPanelPlaces::onEditButtonClicked, this));  	LLComboBox* folder_combo = mLandmarkInfo->getChild<LLComboBox>("folder_combo"); -	folder_combo->setSelectionCallback(boost::bind(&LLPanelPlaces::onEditButtonClicked, this)); +	folder_combo->setCommitCallback(boost::bind(&LLPanelPlaces::onEditButtonClicked, this));  	return TRUE;  } diff --git a/indra/newview/llscrollingpanelparam.cpp b/indra/newview/llscrollingpanelparam.cpp index 1fbaeb94f5..b5e55df1f5 100644 --- a/indra/newview/llscrollingpanelparam.cpp +++ b/indra/newview/llscrollingpanelparam.cpp @@ -73,9 +73,9 @@ LLScrollingPanelParam::LLScrollingPanelParam( const LLPanel::Params& panel_param  	F32 min_weight = param->getMinWeight();  	F32 max_weight = param->getMaxWeight(); -	mHintMin = new LLVisualParamHint( pos_x, pos_y, PARAM_HINT_WIDTH, PARAM_HINT_HEIGHT, mesh, param,  min_weight); +	mHintMin = new LLVisualParamHint( pos_x, pos_y, PARAM_HINT_WIDTH, PARAM_HINT_HEIGHT, mesh, (LLViewerVisualParam*) wearable->getVisualParam(param->getID()),  min_weight);  	pos_x += PARAM_HINT_WIDTH + 3 * BTN_BORDER; -	mHintMax = new LLVisualParamHint( pos_x, pos_y, PARAM_HINT_WIDTH, PARAM_HINT_HEIGHT, mesh, param, max_weight ); +	mHintMax = new LLVisualParamHint( pos_x, pos_y, PARAM_HINT_WIDTH, PARAM_HINT_HEIGHT, mesh, (LLViewerVisualParam*) wearable->getVisualParam(param->getID()), max_weight );  	mHintMin->setAllowsUpdates( FALSE );  	mHintMax->setAllowsUpdates( FALSE ); diff --git a/indra/newview/llsearchcombobox.cpp b/indra/newview/llsearchcombobox.cpp index f95671685b..93a70b6471 100644 --- a/indra/newview/llsearchcombobox.cpp +++ b/indra/newview/llsearchcombobox.cpp @@ -82,7 +82,7 @@ LLSearchComboBox::LLSearchComboBox(const Params&p)  	setButtonVisible(p.dropdown_button_visible);  	mTextEntry->setCommitCallback(boost::bind(&LLComboBox::onTextCommit, this, _2));  	mTextEntry->setKeystrokeCallback(boost::bind(&LLComboBox::onTextEntry, this, _1), NULL); -	setSelectionCallback(boost::bind(&LLSearchComboBox::onSelectionCommit, this)); +	setCommitCallback(boost::bind(&LLSearchComboBox::onSelectionCommit, this));  	setPrearrangeCallback(boost::bind(&LLSearchComboBox::onSearchPrearrange, this, _2));  	mSearchButton->setCommitCallback(boost::bind(&LLSearchComboBox::onTextCommit, this, _2));  } diff --git a/indra/newview/llsidepanelappearance.cpp b/indra/newview/llsidepanelappearance.cpp new file mode 100644 index 0000000000..aeab3e2876 --- /dev/null +++ b/indra/newview/llsidepanelappearance.cpp @@ -0,0 +1,372 @@ +/** + * @file llsidepanelappearance.cpp + * @brief Side Bar "Appearance" panel + * + * $LicenseInfo:firstyear=2009&license=viewergpl$ + * + * Copyright (c) 2004-2009, Linden Research, Inc. + * + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab.  Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 + * + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception + * + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + * + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#include "llviewerprecompiledheaders.h" +#include "llsidepanelappearance.h" + +#include "llagent.h" +#include "llagentwearables.h" +#include "llfiltereditor.h" +#include "llfloaterreg.h" +#include "llfloaterworldmap.h" +#include "llpaneleditwearable.h" +#include "llpaneloutfitsinventory.h" +#include "lltextbox.h" +#include "lluictrlfactory.h" +#include "llviewerregion.h" +#include "llvoavatarself.h" +#include "llwearable.h" + +static LLRegisterPanelClassWrapper<LLSidepanelAppearance> t_appearance("sidepanel_appearance"); + +class LLCurrentlyWornFetchObserver : public LLInventoryFetchObserver +{ +public: +	LLCurrentlyWornFetchObserver(LLSidepanelAppearance *panel) : +		mPanel(panel) +	{} +	~LLCurrentlyWornFetchObserver() {} +	virtual void done() +	{ +		mPanel->inventoryFetched(); +		gInventory.removeObserver(this); +	} +private: +	LLSidepanelAppearance *mPanel; +}; + +LLSidepanelAppearance::LLSidepanelAppearance() : +	LLPanel(), +	mFilterSubString(LLStringUtil::null), +	mFilterEditor(NULL), +	mLookInfo(NULL), +	mCurrLookPanel(NULL) +{ +	//LLUICtrlFactory::getInstance()->buildPanel(this, "panel_appearance.xml"); // Called from LLRegisterPanelClass::defaultPanelClassBuilder() +	mFetchWorn = new LLCurrentlyWornFetchObserver(this); +} + +LLSidepanelAppearance::~LLSidepanelAppearance() +{ +} + +// virtual +BOOL LLSidepanelAppearance::postBuild() +{ +	mEditAppearanceBtn = getChild<LLButton>("editappearance_btn"); +	mEditAppearanceBtn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onEditAppearanceButtonClicked, this)); + +	mWearBtn = getChild<LLButton>("wear_btn"); +	mWearBtn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onWearButtonClicked, this)); + +	mEditBtn = getChild<LLButton>("edit_btn"); +	mEditBtn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onEditButtonClicked, this)); + +	mNewLookBtn = getChild<LLButton>("newlook_btn"); +	mNewLookBtn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onNewOutfitButtonClicked, this)); +	mNewLookBtn->setEnabled(false); + +	mOverflowBtn = getChild<LLButton>("overflow_btn"); + +	mFilterEditor = getChild<LLFilterEditor>("Filter"); +	if (mFilterEditor) +	{ +		mFilterEditor->setCommitCallback(boost::bind(&LLSidepanelAppearance::onFilterEdit, this, _2)); +	} + +	mPanelOutfitsInventory = dynamic_cast<LLPanelOutfitsInventory *>(getChild<LLPanel>("panel_outfits_inventory")); +	mPanelOutfitsInventory->setParent(this); + +	mLookInfo = dynamic_cast<LLPanelLookInfo*>(getChild<LLPanel>("panel_look_info")); +	if (mLookInfo) +	{ +		LLButton* back_btn = mLookInfo->getChild<LLButton>("back_btn"); +		if (back_btn) +		{ +			back_btn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onBackButtonClicked, this)); +		} + +		// *TODO: Assign the action to an appropriate event. +		// mOverflowBtn->setClickedCallback(boost::bind(&LLSidepanelAppearance::toggleMediaPanel, this)); +	} + +	mEditWearable = dynamic_cast<LLPanelEditWearable*>(getChild<LLPanel>("panel_edit_wearable")); +	if (mEditWearable) +	{ +		LLButton* edit_wearable_back_btn = mEditWearable->getChild<LLButton>("back_btn"); +		if (edit_wearable_back_btn) +		{ +			edit_wearable_back_btn->setClickedCallback(boost::bind(&LLSidepanelAppearance::onEditWearBackClicked, this)); +		} +	} + +	mCurrentLookName = getChild<LLTextBox>("currentlook_name"); +	 +	mCurrLookPanel = getChild<LLPanel>("panel_currentlook"); + +	return TRUE; +} + +// virtual +void LLSidepanelAppearance::onOpen(const LLSD& key) +{ +	fetchInventory(); +	refreshCurrentOutfitName(); + +	if(key.size() == 0) +		return; + +	toggleLookInfoPanel(TRUE); +	updateVerbs(); +	 +	mLookInfoType = key["type"].asString(); + +	if (mLookInfoType == "look") +	{ +		LLInventoryCategory *pLook = gInventory.getCategory(key["id"].asUUID()); +		if (pLook) +			mLookInfo->displayLookInfo(pLook); +	} +} + +void LLSidepanelAppearance::onFilterEdit(const std::string& search_string) +{ +	if (mFilterSubString != search_string) +	{ +		mFilterSubString = search_string; + +		// Searches are case-insensitive +		LLStringUtil::toUpper(mFilterSubString); +		LLStringUtil::trimHead(mFilterSubString); + +		mPanelOutfitsInventory->onSearchEdit(mFilterSubString); +	} +} + +void LLSidepanelAppearance::onWearButtonClicked() +{ +	if (!mLookInfo->getVisible()) +	{ +		mPanelOutfitsInventory->onWear(); +	} +} + +void LLSidepanelAppearance::onEditAppearanceButtonClicked() +{ +	if (gAgentWearables.areWearablesLoaded()) +	{ +		gAgent.changeCameraToCustomizeAvatar(); +	} +} + +void LLSidepanelAppearance::onEditButtonClicked() +{ +	toggleLookInfoPanel(FALSE); +	toggleWearableEditPanel(TRUE, NULL); +	/*if (mLookInfo->getVisible()) +	  { +	  } +	  else +	  { +	  mPanelOutfitsInventory->onEdit(); +	  }*/ +} + +void LLSidepanelAppearance::onNewOutfitButtonClicked() +{ +	if (!mLookInfo->getVisible()) +	{ +		mPanelOutfitsInventory->onNew(); +	} +} + + +void LLSidepanelAppearance::onBackButtonClicked() +{ +	toggleLookInfoPanel(FALSE); +} + +void LLSidepanelAppearance::onEditWearBackClicked() +{ +	mEditWearable->saveChanges(); +	toggleWearableEditPanel(FALSE, NULL); +	toggleLookInfoPanel(TRUE); +} + +void LLSidepanelAppearance::toggleLookInfoPanel(BOOL visible) +{ +	if (!mLookInfo) +		return; + +	mLookInfo->setVisible(visible); +	mPanelOutfitsInventory->setVisible(!visible); +	mFilterEditor->setVisible(!visible); +	mWearBtn->setVisible(!visible); +	mEditBtn->setVisible(!visible); +	mNewLookBtn->setVisible(!visible); +	mOverflowBtn->setVisible(!visible); +	mCurrLookPanel->setVisible(!visible); +} + +void LLSidepanelAppearance::toggleWearableEditPanel(BOOL visible, LLWearable *wearable) +{ +	if (!wearable) +	{ +		wearable = gAgentWearables.getWearable(WT_SHAPE, 0); +	} +	if (!mEditWearable || !wearable) +	{ +		return; +	} + +	mEditWearable->setVisible(visible); +	mFilterEditor->setVisible(!visible); +	mPanelOutfitsInventory->setVisible(!visible); +} + +void LLSidepanelAppearance::updateVerbs() +{ +	bool is_look_info_visible = mLookInfo->getVisible(); +	mOverflowBtn->setEnabled(false); + +	if (!is_look_info_visible) +	{ +		const bool is_correct_type = (mPanelOutfitsInventory->getCorrectListenerForAction() != NULL); +		mEditBtn->setEnabled(is_correct_type); +		mWearBtn->setEnabled(is_correct_type); +	} +	else +	{ +		mEditBtn->setEnabled(FALSE); +		mWearBtn->setEnabled(FALSE); +	} +} + +void LLSidepanelAppearance::refreshCurrentOutfitName(const std::string name) +{ +	if (name == "") +	{ +		const LLUUID current_outfit_cat = gInventory.findCategoryUUIDForType(LLFolderType::FT_CURRENT_OUTFIT); +		LLInventoryModel::cat_array_t cat_array; +		LLInventoryModel::item_array_t item_array; +		// Can't search on AT_OUTFIT since links to categories return AT_CATEGORY for type since they don't +		// return preferred type. +		LLIsType is_category( LLAssetType::AT_CATEGORY );  +		gInventory.collectDescendentsIf(current_outfit_cat, +										cat_array, +										item_array, +										false, +										is_category, +										false); +		for (LLInventoryModel::item_array_t::const_iterator iter = item_array.begin(); +			 iter != item_array.end(); +			 iter++) +		{ +			const LLViewerInventoryItem *item = (*iter); +			const LLViewerInventoryCategory *cat = item->getLinkedCategory(); +			if (cat && cat->getPreferredType() == LLFolderType::FT_OUTFIT) +			{ +				mCurrentLookName->setText(cat->getName()); +				return; +			} +		} +		mCurrentLookName->setText(std::string("")); +	} +	else +	{ +		mCurrentLookName->setText(name); +	} +} + +//static +void LLSidepanelAppearance::editWearable(LLWearable *wearable, void *data) +{ +	LLSidepanelAppearance *panel = (LLSidepanelAppearance*) data; +	panel->toggleLookInfoPanel(FALSE); +	panel->toggleWearableEditPanel(TRUE, wearable); +} + +// Fetch currently worn items and only enable the New Look button after everything's been +// fetched.  Alternatively, we could stuff this logic into llagentwearables::makeNewOutfitLinks. +void LLSidepanelAppearance::fetchInventory() +{ + +	mNewLookBtn->setEnabled(false); +	LLInventoryFetchObserver::item_ref_t ids; +	LLUUID item_id; +	for(S32 type = (S32)WT_SHAPE; type < (S32)WT_COUNT; ++type) +	{ +		// MULTI_WEARABLE: +		item_id = gAgentWearables.getWearableItemID((EWearableType)type,0); +		if(item_id.notNull()) +		{ +			ids.push_back(item_id); +		} +	} + +	LLVOAvatarSelf* avatar = gAgent.getAvatarObject(); +	if( avatar ) +	{ +		for (LLVOAvatar::attachment_map_t::const_iterator iter = avatar->mAttachmentPoints.begin();  +			 iter != avatar->mAttachmentPoints.end(); ++iter) +		{ +			LLViewerJointAttachment* attachment = iter->second; +			if (!attachment) continue; +			for (LLViewerJointAttachment::attachedobjs_vec_t::iterator attachment_iter = attachment->mAttachedObjects.begin(); +				 attachment_iter != attachment->mAttachedObjects.end(); +				 ++attachment_iter) +			{ +				LLViewerObject* attached_object = (*attachment_iter); +				if (!attached_object) continue; +				const LLUUID& item_id = attached_object->getItemID(); +				if (item_id.isNull()) continue; +				ids.push_back(item_id); +			} +		} +	} + +	mFetchWorn->fetchItems(ids); +	// If no items to be fetched, done will never be triggered. +	// TODO: Change LLInventoryFetchObserver::fetchItems to trigger done() on this condition. +	if (mFetchWorn->isEverythingComplete()) +	{ +		mFetchWorn->done(); +	} +	else +	{ +		gInventory.addObserver(mFetchWorn); +	} +} + +void LLSidepanelAppearance::inventoryFetched() +{ +	mNewLookBtn->setEnabled(true); +} diff --git a/indra/newview/llsidepanelappearance.h b/indra/newview/llsidepanelappearance.h new file mode 100644 index 0000000000..496a1fef72 --- /dev/null +++ b/indra/newview/llsidepanelappearance.h @@ -0,0 +1,102 @@ +/**  + * @file llsidepanelappearance.h + * @brief Side Bar "Appearance" panel + * + * $LicenseInfo:firstyear=2009&license=viewergpl$ + *  + * Copyright (c) 2004-2009, Linden Research, Inc. + *  + * Second Life Viewer Source Code + * The source code in this file ("Source Code") is provided by Linden Lab + * to you under the terms of the GNU General Public License, version 2.0 + * ("GPL"), unless you have obtained a separate licensing agreement + * ("Other License"), formally executed by you and Linden Lab.  Terms of + * the GPL can be found in doc/GPL-license.txt in this distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 + *  + * There are special exceptions to the terms and conditions of the GPL as + * it is applied to this Source Code. View the full text of the exception + * in the file doc/FLOSS-exception.txt in this software distribution, or + * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception + *  + * By copying, modifying or distributing this software, you acknowledge + * that you have read and understood your obligations described above, + * and agree to abide by those obligations. + *  + * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO + * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, + * COMPLETENESS OR PERFORMANCE. + * $/LicenseInfo$ + */ + +#ifndef LL_LLSIDEPANELAPPEARANCE_H +#define LL_LLSIDEPANELAPPEARANCE_H + +#include "llpanel.h" +#include "llinventoryobserver.h" + +#include "llinventory.h" +#include "llpanellookinfo.h" + +class LLFilterEditor; +class LLCurrentlyWornFetchObserver; +class LLPanelEditWearable; +class LLWearable; +class LLPanelOutfitsInventory; + +class LLSidepanelAppearance : public LLPanel +{ +public: +	LLSidepanelAppearance(); +	virtual ~LLSidepanelAppearance(); + +	/*virtual*/ BOOL postBuild(); +	/*virtual*/ void onOpen(const LLSD& key); + +	void refreshCurrentOutfitName(const std::string name = ""); + +	static void editWearable(LLWearable *wearable, void *data); + +	void fetchInventory(); +	void inventoryFetched(); +	void updateVerbs(); + +private: +	void onFilterEdit(const std::string& search_string); + +	void onEditAppearanceButtonClicked(); +	void onWearButtonClicked(); +	void onEditButtonClicked(); +	void onNewOutfitButtonClicked(); +	void onBackButtonClicked(); +	void onEditWearBackClicked(); +	void toggleLookInfoPanel(BOOL visible); +	void toggleWearableEditPanel(BOOL visible, LLWearable* wearable); + +	LLFilterEditor*			mFilterEditor; +	LLPanelOutfitsInventory* mPanelOutfitsInventory; +	LLPanelLookInfo*		mLookInfo; +	LLPanelEditWearable*	mEditWearable; + +	LLButton*					mEditAppearanceBtn; +	LLButton*					mWearBtn; +	LLButton*					mEditBtn; +	LLButton*					mNewLookBtn; +	LLButton*					mOverflowBtn; +	LLPanel*					mCurrLookPanel; + +	LLTextBox*					mCurrentLookName; + +	// Used to make sure the user's inventory is in memory. +	LLCurrentlyWornFetchObserver* mFetchWorn; + +	// Search string for filtering landmarks and teleport +	// history locations +	std::string					mFilterSubString; + +	// Information type currently shown in Look Information panel +	std::string					mLookInfoType; + +}; + +#endif //LL_LLSIDEPANELAPPEARANCE_H diff --git a/indra/newview/lltexturecache.cpp b/indra/newview/lltexturecache.cpp index c33c652935..845e71378a 100644 --- a/indra/newview/lltexturecache.cpp +++ b/indra/newview/lltexturecache.cpp @@ -917,7 +917,7 @@ BOOL LLTextureCache::isInLocal(const LLUUID& id)  //static  const S32 MAX_REASONABLE_FILE_SIZE = 512*1024*1024; // 512 MB -F32 LLTextureCache::sHeaderCacheVersion = 1.3f; +F32 LLTextureCache::sHeaderCacheVersion = 1.4f;  U32 LLTextureCache::sCacheMaxEntries = MAX_REASONABLE_FILE_SIZE / TEXTURE_CACHE_ENTRY_SIZE;  S64 LLTextureCache::sCacheMaxTexturesSize = 0; // no limit  const char* entries_filename = "texture.entries"; diff --git a/indra/newview/lltoolmorph.cpp b/indra/newview/lltoolmorph.cpp index d7d7b5f44b..4fb75f7a49 100644 --- a/indra/newview/lltoolmorph.cpp +++ b/indra/newview/lltoolmorph.cpp @@ -146,8 +146,9 @@ void LLVisualParamHint::preRender(BOOL clear_depth)  {  	LLVOAvatarSelf* avatarp = gAgent.getAvatarObject(); -	mLastParamWeight = avatarp->getVisualParamWeight(mVisualParam); -	avatarp->setVisualParamWeight(mVisualParam, mVisualParamWeight); +	mLastParamWeight = mVisualParam->getWeight(); +	mVisualParam->setWeight(mVisualParamWeight, FALSE); +	avatarp->setVisualParamWeight(mVisualParam->getID(), mVisualParamWeight, FALSE);  	avatarp->setVisualParamWeight("Blink_Left", 0.f);  	avatarp->setVisualParamWeight("Blink_Right", 0.f);  	avatarp->updateComposites(); @@ -242,7 +243,8 @@ BOOL LLVisualParamHint::render()  		gGL.setSceneBlendType(LLRender::BT_ALPHA);  		gGL.setAlphaRejectSettings(LLRender::CF_DEFAULT);  	} -	avatarp->setVisualParamWeight(mVisualParam, mLastParamWeight); +	avatarp->setVisualParamWeight(mVisualParam->getID(), mLastParamWeight); +	mVisualParam->setWeight(mLastParamWeight, FALSE);  	gGL.color4f(1,1,1,1);  	mGLTexturep->setGLTextureCreated(true);  	return TRUE; diff --git a/indra/newview/llviewerinventory.cpp b/indra/newview/llviewerinventory.cpp index 1d62ead843..089535dfab 100644 --- a/indra/newview/llviewerinventory.cpp +++ b/indra/newview/llviewerinventory.cpp @@ -1215,11 +1215,6 @@ void LLViewerInventoryItem::rename(const std::string& n)  const LLPermissions& LLViewerInventoryItem::getPermissions() const  { -	if (const LLViewerInventoryItem *linked_item = getLinkedItem()) -	{ -		return linked_item->getPermissions(); -	} -  	// Use the actual permissions of the symlink, not its parent.  	return LLInventoryItem::getPermissions();	  } diff --git a/indra/newview/llviewermenu.cpp b/indra/newview/llviewermenu.cpp index 68a9aaef75..6a6aa1061d 100644 --- a/indra/newview/llviewermenu.cpp +++ b/indra/newview/llviewermenu.cpp @@ -5189,7 +5189,7 @@ void show_debug_menus()  		gMenuBarView->setItemEnabled("Develop", qamode);  		// Server ('Admin') menu hidden when not in godmode. -		const bool show_server_menu = debug && (gAgent.getGodLevel() > GOD_NOT || gAgent.getAdminOverride()); +		const bool show_server_menu = (gAgent.getGodLevel() > GOD_NOT || (debug && gAgent.getAdminOverride()));  		gMenuBarView->setItemVisible("Admin", show_server_menu);  		gMenuBarView->setItemEnabled("Admin", show_server_menu);  	} diff --git a/indra/newview/llviewerwindow.cpp b/indra/newview/llviewerwindow.cpp index 615eb1db9a..c21c287fb6 100644 --- a/indra/newview/llviewerwindow.cpp +++ b/indra/newview/llviewerwindow.cpp @@ -3942,7 +3942,7 @@ BOOL LLViewerWindow::rawSnapshot(LLImageRaw *raw, S32 image_width, S32 image_hei  		return FALSE ;  	} -	BOOL high_res = scale_factor > 1.f; +	BOOL high_res = scale_factor >= 2.f; // Font scaling is slow, only do so if rez is much higher  	if (high_res)  	{  		send_agent_pause(); diff --git a/indra/newview/llvoavatar.cpp b/indra/newview/llvoavatar.cpp index b6c1ee2f11..75e35e5221 100644 --- a/indra/newview/llvoavatar.cpp +++ b/indra/newview/llvoavatar.cpp @@ -6267,7 +6267,7 @@ LLColor4 LLVOAvatar::getDummyColor()  	return DUMMY_COLOR;  } -void LLVOAvatar::dumpAvatarTEs( const std::string& context ) +void LLVOAvatar::dumpAvatarTEs( const std::string& context ) const  {	  	/* const char* te_name[] = {  			"TEX_HEAD_BODYPAINT   ", diff --git a/indra/newview/llvoavatar.h b/indra/newview/llvoavatar.h index 2fd1a506a9..4b3e850e7a 100644 --- a/indra/newview/llvoavatar.h +++ b/indra/newview/llvoavatar.h @@ -889,7 +889,7 @@ public:  	static void			dumpArchetypeXML(void*);  	static void			dumpBakedStatus();  	const std::string 	getBakedStatusForPrintout() const; -	void				dumpAvatarTEs(const std::string& context); +	void				dumpAvatarTEs(const std::string& context) const;  	static F32 			sUnbakedTime; // Total seconds with >=1 unbaked avatars  	static F32 			sUnbakedUpdateTime; // Last time stats were updated (to prevent multiple updates per frame)  diff --git a/indra/newview/llvoavatarself.cpp b/indra/newview/llvoavatarself.cpp index 711e9f90fc..d9c5e932a2 100644 --- a/indra/newview/llvoavatarself.cpp +++ b/indra/newview/llvoavatarself.cpp @@ -2074,6 +2074,49 @@ void LLVOAvatarSelf::setInvisible(BOOL newvalue)  	}  } +// HACK: this will null out the avatar's local texture IDs before the TE message is sent +//       to ensure local texture IDs are not sent to other clients in the area. +//       this is a short-term solution. The long term solution will be to not set the texture +//       IDs in the avatar object, and keep them only in the wearable. +//       This will involve further refactoring that is too risky for the initial release of 2.0. +bool LLVOAvatarSelf::sendAppearanceMessage(LLMessageSystem *mesgsys) const +{ +	LLUUID texture_id[TEX_NUM_INDICES]; +	// pack away current TEs to make sure we don't send them out +	for (LLVOAvatarDictionary::Textures::const_iterator iter = LLVOAvatarDictionary::getInstance()->getTextures().begin(); +		 iter != LLVOAvatarDictionary::getInstance()->getTextures().end(); +		 ++iter) +	{ +		const ETextureIndex index = iter->first; +		const LLVOAvatarDictionary::TextureEntry *texture_dict = iter->second; +		if (!texture_dict->mIsBakedTexture) +		{ +			LLTextureEntry* entry = getTE((U8) index); +			texture_id[index] = entry->getID(); +			entry->setID(IMG_DEFAULT_AVATAR); +		} +	} + +	bool success = packTEMessage(mesgsys); + +	// unpack TEs to make sure we don't re-trigger a bake +	for (LLVOAvatarDictionary::Textures::const_iterator iter = LLVOAvatarDictionary::getInstance()->getTextures().begin(); +		 iter != LLVOAvatarDictionary::getInstance()->getTextures().end(); +		 ++iter) +	{ +		const ETextureIndex index = iter->first; +		const LLVOAvatarDictionary::TextureEntry *texture_dict = iter->second; +		if (!texture_dict->mIsBakedTexture) +		{ +			LLTextureEntry* entry = getTE((U8) index); +			entry->setID(texture_id[index]); +		} +	} + +	return success; +} + +  //------------------------------------------------------------------------  // needsRenderBeam()  //------------------------------------------------------------------------ diff --git a/indra/newview/llvoavatarself.h b/indra/newview/llvoavatarself.h index 6702f030fe..a1cad82eff 100644 --- a/indra/newview/llvoavatarself.h +++ b/indra/newview/llvoavatarself.h @@ -310,6 +310,7 @@ public:  public:  	static void		onChangeSelfInvisible(BOOL newvalue);  	void			setInvisible(BOOL newvalue); +	bool			sendAppearanceMessage(LLMessageSystem *mesgsys) const;  /**                    Appearance   **                                                                            ** diff --git a/indra/newview/llvoicechannel.cpp b/indra/newview/llvoicechannel.cpp index 21054dacd0..8f63df8c29 100644 --- a/indra/newview/llvoicechannel.cpp +++ b/indra/newview/llvoicechannel.cpp @@ -754,6 +754,8 @@ LLVoiceChannelP2P::LLVoiceChannelP2P(const LLUUID& session_id, const std::string  void LLVoiceChannelP2P::handleStatusChange(EStatusType type)  { +	llinfos << "P2P CALL CHANNEL STATUS CHANGE: incoming=" << int(mReceivedCall) << " newstatus=" << LLVoiceClientStatusObserver::status2string(type) << " (mState=" << mState << ")" << llendl; +  	// status updates  	switch(type)  	{ @@ -880,6 +882,8 @@ void LLVoiceChannelP2P::setState(EState state)  	// *HACK: Open/close the call window if needed.  	toggleCallWindowIfNeeded(state); +	llinfos << "P2P CALL STATE CHANGE: incoming=" << int(mReceivedCall) << " oldstate=" << mState << " newstate=" << state << llendl; +  	if (mReceivedCall) // incoming call  	{  		// you only "answer" voice invites in p2p mode @@ -896,7 +900,8 @@ void LLVoiceChannelP2P::setState(EState state)  		mCallDialogPayload["session_id"] = mSessionID;  		mCallDialogPayload["session_name"] = mSessionName;  		mCallDialogPayload["other_user_id"] = mOtherUserID; -		if (state == STATE_RINGING) +		if (state == STATE_RINGING || +		    state == STATE_CALL_STARTED)  		{  			// *HACK: open outgoing call floater if needed, might be better done elsewhere.  			// *TODO: should move this squirrelly ui-fudging crap into LLOutgoingCallDialog itself @@ -908,6 +913,7 @@ void LLVoiceChannelP2P::setState(EState state)  					ocd->getChild<LLTextBox>("calling")->setVisible(true);  					ocd->getChild<LLTextBox>("leaving")->setVisible(true);  					ocd->getChild<LLTextBox>("connecting")->setVisible(false); +					ocd->getChild<LLTextBox>("noanswer")->setVisible(false);  				}  			}  		} @@ -919,16 +925,29 @@ void LLVoiceChannelP2P::setState(EState state)  					ocd->getChild<LLTextBox>("calling")->setVisible(false);  					ocd->getChild<LLTextBox>("leaving")->setVisible(false);  					ocd->getChild<LLTextBox>("connecting")->setVisible(true); +					ocd->getChild<LLTextBox>("noanswer")->setVisible(false);  				}			  				}*/ +		else if (state == STATE_ERROR) +		{ +			LLOutgoingCallDialog *ocd = dynamic_cast<LLOutgoingCallDialog*>(LLFloaterReg::showInstance("outgoing_call", mCallDialogPayload, TRUE)); +			if (ocd) +			{ +				ocd->getChild<LLTextBox>("calling")->setVisible(false); +				ocd->getChild<LLTextBox>("leaving")->setVisible(false); +				ocd->getChild<LLTextBox>("connecting")->setVisible(false); +				ocd->getChild<LLTextBox>("noanswer")->setVisible(true); +			}			 +		}  		else if (state == STATE_HUNG_UP ||  			 state == STATE_CONNECTED)  		{ -				LLOutgoingCallDialog *ocd = dynamic_cast<LLOutgoingCallDialog*>(LLFloaterReg::showInstance("outgoing_call", mCallDialogPayload, TRUE)); -				if (ocd) -				{ -					ocd->closeFloater(); -				}			 +			// hide popup +			LLOutgoingCallDialog *ocd = dynamic_cast<LLOutgoingCallDialog*>(LLFloaterReg::showInstance("outgoing_call", mCallDialogPayload, TRUE)); +			if (ocd) +			{ +				ocd->closeFloater(); +			}			  		}  	} diff --git a/indra/newview/llwearable.cpp b/indra/newview/llwearable.cpp index e37dffd526..ced0b64896 100644 --- a/indra/newview/llwearable.cpp +++ b/indra/newview/llwearable.cpp @@ -38,6 +38,7 @@  #include "lllocaltextureobject.h"  #include "llviewertexturelist.h"  #include "llinventorymodel.h" +#include "llinventoryobserver.h"  #include "llviewerregion.h"  #include "llvoavatar.h"  #include "llvoavatarself.h" @@ -225,7 +226,13 @@ BOOL LLWearable::importFile( LLFILE* file )  		return FALSE;  	} -	if( mDefinitionVersion > LLWearable::sCurrentDefinitionVersion ) + +	// Temoprary hack to allow wearables with definition version 24 to still load. +	// This should only affect lindens and NDA'd testers who have saved wearables in 2.0 +	// the extra check for version == 24 can be removed before release, once internal testers +	// have loaded these wearables again. See hack pt 2 at bottom of function to ensure that +	// these wearables get re-saved with version definition 22. +	if( mDefinitionVersion > LLWearable::sCurrentDefinitionVersion && mDefinitionVersion != 24 )  	{  		llwarns << "Wearable asset has newer version (" << mDefinitionVersion << ") than XML (" << LLWearable::sCurrentDefinitionVersion << ")" << llendl;  		return FALSE; @@ -414,6 +421,18 @@ BOOL LLWearable::importFile( LLFILE* file )  	// copy all saved param values to working params  	revertValues(); +	// Hack pt 2. If the wearable we just loaded has definition version 24, +	// then force a re-save of this wearable after slamming the version number to 22. +	// This number was incorrectly incremented for internal builds before release, and +	// this fix will ensure that the affected wearables are re-saved with the right version number. +	// the versions themselves are compatible. This code can be removed before release. +	if( mDefinitionVersion == 24 ) +	{ +		mDefinitionVersion = 22; +		U32 index = gAgentWearables.getWearableIndex(this); +		gAgentWearables.saveWearable(mType,index,TRUE); +	} +  	return TRUE;  } @@ -1080,6 +1099,12 @@ void LLWearable::destroyTextures()  	mSavedTEMap.clear();  } + +void LLWearable::setLabelUpdated() const +{  +	gInventory.addChangedMask(LLInventoryObserver::LABEL, getItemID()); +} +  struct LLWearableSaveData  {  	EWearableType mType; diff --git a/indra/newview/llwearable.h b/indra/newview/llwearable.h index fd19a86406..0863adb7f5 100644 --- a/indra/newview/llwearable.h +++ b/indra/newview/llwearable.h @@ -128,6 +128,8 @@ public:  	BOOL				isOnTop() const; +	// Something happened that requires the wearable's label to be updated (e.g. worn/unworn). +	void				setLabelUpdated() const;  private:  	typedef std::map<S32, LLLocalTextureObject*> te_map_t; diff --git a/indra/newview/skins/default/html/da/loading/loading.html b/indra/newview/skins/default/html/da/loading/loading.html index 5f3426eb60..cdad5702b9 100644 --- a/indra/newview/skins/default/html/da/loading/loading.html +++ b/indra/newview/skins/default/html/da/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Indlæser... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Indlæser...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/de/loading/loading.html b/indra/newview/skins/default/html/de/loading/loading.html index 44a621b216..3eddbc24f5 100644 --- a/indra/newview/skins/default/html/de/loading/loading.html +++ b/indra/newview/skins/default/html/de/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Wird geladen... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Wird geladen...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/en-us/loading/loading.html b/indra/newview/skins/default/html/en-us/loading/loading.html index 1c62d2f73e..34e5c84c4d 100644 --- a/indra/newview/skins/default/html/en-us/loading/loading.html +++ b/indra/newview/skins/default/html/en-us/loading/loading.html @@ -1,9 +1,9 @@ -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="sl_logo_rotate_black.gif" align="absmiddle"><br/>   loading... -		</td> -	</tr> -</table> -</body> +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="sl_logo_rotate_black.gif" align="absmiddle"><br/>   loading...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/es/loading/loading.html b/indra/newview/skins/default/html/es/loading/loading.html index c4260b34c0..f03284ba8c 100644 --- a/indra/newview/skins/default/html/es/loading/loading.html +++ b/indra/newview/skins/default/html/es/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Cargando... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Cargando...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/fr/loading/loading.html b/indra/newview/skins/default/html/fr/loading/loading.html index b3953448e9..23c0ef03bc 100644 --- a/indra/newview/skins/default/html/fr/loading/loading.html +++ b/indra/newview/skins/default/html/fr/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Chargement... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Chargement...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/hu/loading/loading.html b/indra/newview/skins/default/html/hu/loading/loading.html index ab15a073ba..ade91f76c2 100644 --- a/indra/newview/skins/default/html/hu/loading/loading.html +++ b/indra/newview/skins/default/html/hu/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Betöltés folyamatban... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Betöltés folyamatban...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/it/loading/loading.html b/indra/newview/skins/default/html/it/loading/loading.html index ab37e41f04..0f9af31f6e 100644 --- a/indra/newview/skins/default/html/it/loading/loading.html +++ b/indra/newview/skins/default/html/it/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Attendi... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Attendi...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/ja/loading/loading.html b/indra/newview/skins/default/html/ja/loading/loading.html index 35cf74a35f..069dc5d12f 100644 --- a/indra/newview/skins/default/html/ja/loading/loading.html +++ b/indra/newview/skins/default/html/ja/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   ロード中... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   ロード中...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/nl/loading/loading.html b/indra/newview/skins/default/html/nl/loading/loading.html index 0215bd7e47..39a8691f3f 100644 --- a/indra/newview/skins/default/html/nl/loading/loading.html +++ b/indra/newview/skins/default/html/nl/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Laden... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Laden...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/pl/loading/loading.html b/indra/newview/skins/default/html/pl/loading/loading.html index 50f3dfb0c5..515890c2d5 100644 --- a/indra/newview/skins/default/html/pl/loading/loading.html +++ b/indra/newview/skins/default/html/pl/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Ładowanie... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Ładowanie...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/pt/loading/loading.html b/indra/newview/skins/default/html/pt/loading/loading.html index a83e1123d0..635ea62406 100644 --- a/indra/newview/skins/default/html/pt/loading/loading.html +++ b/indra/newview/skins/default/html/pt/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Carregando... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Carregando...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/ru/loading/loading.html b/indra/newview/skins/default/html/ru/loading/loading.html index 892c0b9f7f..dcc0d73c1a 100644 --- a/indra/newview/skins/default/html/ru/loading/loading.html +++ b/indra/newview/skins/default/html/ru/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Загрузка... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Загрузка...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/tr/loading/loading.html b/indra/newview/skins/default/html/tr/loading/loading.html index 1ac07bff34..e7812e7c8e 100644 --- a/indra/newview/skins/default/html/tr/loading/loading.html +++ b/indra/newview/skins/default/html/tr/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Yükleniyor... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Yükleniyor...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/uk/loading/loading.html b/indra/newview/skins/default/html/uk/loading/loading.html index 3b5b8679b4..0f67994635 100644 --- a/indra/newview/skins/default/html/uk/loading/loading.html +++ b/indra/newview/skins/default/html/uk/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Завантаж... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   Завантаж...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/html/zh/loading/loading.html b/indra/newview/skins/default/html/zh/loading/loading.html index d1d5d25c92..462ea291d9 100644 --- a/indra/newview/skins/default/html/zh/loading/loading.html +++ b/indra/newview/skins/default/html/zh/loading/loading.html @@ -1,10 +1,10 @@ -<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head> -<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;"> -<table width="100%" height="100%" border="0"> -	<tr> -		<td align="center" valign="middle" style="font-size:0.8em;"> -			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   请等待... -		</td> -	</tr> -</table> -</body> +<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /></head>
 +<body style="background-color:#000000;font-family:verdana,helvetica,sans-serif;font-size:62.5%;color:#e9f1f8;">
 +<table width="100%" height="100%" border="0">
 +	<tr>
 +		<td align="center" valign="middle" style="font-size:0.8em;">
 +			<img src="../../en-us/loading/sl_logo_rotate_black.gif" align="absmiddle"><br/>   请等待...
 +		</td>
 +	</tr>
 +</table>
 +</body>
 diff --git a/indra/newview/skins/default/xui/da/panel_edit_profile.xml b/indra/newview/skins/default/xui/da/panel_edit_profile.xml index b4d0fa20ef..74b7c7dd72 100644 --- a/indra/newview/skins/default/xui/da/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/da/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Beboer" /> -   <string name="AcctTypeTrial" -    value="På prøve" /> -   <string name="AcctTypeCharterMember" -    value="æresmedlem" /> -   <string name="AcctTypeEmployee" -    value="Linden Lab medarbejder" /> -   <string name="PaymentInfoUsed" -    value="Betalende medlem" /> -   <string name="PaymentInfoOnFile" -    value="Registreret betalende" /> -   <string name="NoPaymentInfoOnFile" -    value="Ingen betalingsinfo" /> -   <string name="AgeVerified" -    value="Alders-checket" /> -   <string name="NotAgeVerified" -    value="Ikke alders-checket" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=da -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Partner:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Optaget autosvar: -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Beboer" />
 +   <string name="AcctTypeTrial"
 +    value="På prøve" />
 +   <string name="AcctTypeCharterMember"
 +    value="æresmedlem" />
 +   <string name="AcctTypeEmployee"
 +    value="Linden Lab medarbejder" />
 +   <string name="PaymentInfoUsed"
 +    value="Betalende medlem" />
 +   <string name="PaymentInfoOnFile"
 +    value="Registreret betalende" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Ingen betalingsinfo" />
 +   <string name="AgeVerified"
 +    value="Alders-checket" />
 +   <string name="NotAgeVerified"
 +    value="Ikke alders-checket" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=da
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Partner:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Optaget autosvar:
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/skins/default/xui/en/floater_outgoing_call.xml b/indra/newview/skins/default/xui/en/floater_outgoing_call.xml index 82417de8a7..ae4d5042ef 100644 --- a/indra/newview/skins/default/xui/en/floater_outgoing_call.xml +++ b/indra/newview/skins/default/xui/en/floater_outgoing_call.xml @@ -59,6 +59,17 @@ Connecting to [CALLEE_NAME]  Calling [CALLEE_NAME]      </text>      <text +     font="SansSerifLarge" +     height="20" +     layout="topleft" +     left="77" +     name="noanswer" +     top="27" +     width="315" +     word_wrap="true"> +No Answer.  Please try again later. +    </text> +    <text       font="SansSerif"       height="50"       layout="topleft" diff --git a/indra/newview/skins/default/xui/en/floater_stats.xml b/indra/newview/skins/default/xui/en/floater_stats.xml index 68a4867167..f9dacf0207 100644 --- a/indra/newview/skins/default/xui/en/floater_stats.xml +++ b/indra/newview/skins/default/xui/en/floater_stats.xml @@ -405,179 +405,179 @@  				 show_bar="false"  				 show_mean="false" >  			  </stat_bar> +		  </stat_view> -			  <stat_bar -				 name="simagentups" -				 label="Agent Updates/Sec" -				 stat="simagentups" -				 precision="1" -				 bar_min="0.f" -				 bar_max="100.f"  -				 tick_spacing="25.f" -				 label_spacing="50.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simagentups" +			   label="Agent Updates/Sec" +			   stat="simagentups" +			   precision="1" +			   bar_min="0.f" +			   bar_max="100.f"  +			   tick_spacing="25.f" +			   label_spacing="50.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simmainagents" -				 label="Main Agents" -				 stat="simmainagents" -				 precision="0" -				 bar_min="0.f" -				 bar_max="80.f"  -				 tick_spacing="10.f" -				 label_spacing="40.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simmainagents" +			   label="Main Agents" +			   stat="simmainagents" +			   precision="0" +			   bar_min="0.f" +			   bar_max="80.f"  +			   tick_spacing="10.f" +			   label_spacing="40.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simchildagents" -				 label="Child Agents" -				 stat="simchildagents" -				 precision="0" -				 bar_min="0.f" -				 bar_max="40.f"  -				 tick_spacing="5.f" -				 label_spacing="10.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simchildagents" +			   label="Child Agents" +			   stat="simchildagents" +			   precision="0" +			   bar_min="0.f" +			   bar_max="40.f"  +			   tick_spacing="5.f" +			   label_spacing="10.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simobjects" -				 label="Objects" -				 stat="simobjects" -				 precision="0" -				 bar_min="0.f" -				 bar_max="30000.f"  -				 tick_spacing="5000.f" -				 label_spacing="10000.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simobjects" +			   label="Objects" +			   stat="simobjects" +			   precision="0" +			   bar_min="0.f" +			   bar_max="30000.f"  +			   tick_spacing="5000.f" +			   label_spacing="10000.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simactiveobjects" -				 label="Active Objects" -				 stat="simactiveobjects" -				 precision="0" -				 bar_min="0.f" -				 bar_max="800.f"  -				 tick_spacing="100.f" -				 label_spacing="200.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simactiveobjects" +			   label="Active Objects" +			   stat="simactiveobjects" +			   precision="0" +			   bar_min="0.f" +			   bar_max="800.f"  +			   tick_spacing="100.f" +			   label_spacing="200.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simactivescripts" -				 label="Active Scripts" -				 stat="simactivescripts" -				 precision="0" -				 bar_min="0.f" -				 bar_max="800.f"  -				 tick_spacing="100.f" -				 label_spacing="200.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simactivescripts" +			   label="Active Scripts" +			   stat="simactivescripts" +			   precision="0" +			   bar_min="0.f" +			   bar_max="800.f"  +			   tick_spacing="100.f" +			   label_spacing="200.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simscripteps" -				 label="Script Events" -				 stat="simscripteps" -				 unit_label="eps" -				 precision="0" -				 bar_min="0.f" -				 bar_max="20000.f"  -				 tick_spacing="2500.f" -				 label_spacing="5000.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simscripteps" +			   label="Script Events" +			   stat="simscripteps" +			   unit_label="eps" +			   precision="0" +			   bar_min="0.f" +			   bar_max="20000.f"  +			   tick_spacing="2500.f" +			   label_spacing="5000.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="siminpps" -				 label="Packets In" -				 stat="siminpps" -				 unit_label="pps" -				 precision="0" -				 bar_min="0.f" -				 bar_max="2000.f"  -				 tick_spacing="250.f" -				 label_spacing="1000.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="siminpps" +			   label="Packets In" +			   stat="siminpps" +			   unit_label="pps" +			   precision="0" +			   bar_min="0.f" +			   bar_max="2000.f"  +			   tick_spacing="250.f" +			   label_spacing="1000.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simoutpps" -				 label="Packets Out" -				 stat="simoutpps" -				 unit_label="pps"  -				 precision="0" -				 bar_min="0.f" -				 bar_max="2000.f"  -				 tick_spacing="250.f" -				 label_spacing="1000.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simoutpps" +			   label="Packets Out" +			   stat="simoutpps" +			   unit_label="pps"  +			   precision="0" +			   bar_min="0.f" +			   bar_max="2000.f"  +			   tick_spacing="250.f" +			   label_spacing="1000.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simpendingdownloads" -				 label="Pending Downloads" -				 stat="simpendingdownloads" -				 precision="0" -				 bar_min="0.f" -				 bar_max="800.f"  -				 tick_spacing="100.f" -				 label_spacing="200.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simpendingdownloads" +			   label="Pending Downloads" +			   stat="simpendingdownloads" +			   precision="0" +			   bar_min="0.f" +			   bar_max="800.f"  +			   tick_spacing="100.f" +			   label_spacing="200.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simpendinguploads" -				 label="Pending Uploads" -				 stat="simpendinguploads" -				 precision="0" -				 bar_min="0.f" -				 bar_max="100.f"  -				 tick_spacing="25.f" -				 label_spacing="50.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> +			<stat_bar +			   name="simpendinguploads" +			   label="Pending Uploads" +			   stat="simpendinguploads" +			   precision="0" +			   bar_min="0.f" +			   bar_max="100.f"  +			   tick_spacing="25.f" +			   label_spacing="50.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar> -			  <stat_bar -				 name="simtotalunackedbytes" -				 label="Total Unacked Bytes" -				 stat="simtotalunackedbytes" -				 unit_label="kb" -				 precision="0" -				 bar_min="0.f" -				 bar_max="100000.f"  -				 tick_spacing="25000.f" -				 label_spacing="50000.f"  -				 show_per_sec="false" -				 show_bar="false" -				 show_mean="false" > -			  </stat_bar> -			</stat_view> +			<stat_bar +			   name="simtotalunackedbytes" +			   label="Total Unacked Bytes" +			   stat="simtotalunackedbytes" +			   unit_label="kb" +			   precision="0" +			   bar_min="0.f" +			   bar_max="100000.f"  +			   tick_spacing="25000.f" +			   label_spacing="50000.f"  +			   show_per_sec="false" +			   show_bar="false" +			   show_mean="false" > +			</stat_bar>  			<stat_view  			   name="simperf" diff --git a/indra/newview/skins/default/xui/en/floater_world_map.xml b/indra/newview/skins/default/xui/en/floater_world_map.xml index 387ffbd5b3..c60cc163c8 100644 --- a/indra/newview/skins/default/xui/en/floater_world_map.xml +++ b/indra/newview/skins/default/xui/en/floater_world_map.xml @@ -340,6 +340,8 @@           label="Landmarks"           name="item1"           value="None" /> +		<combo_box.commit_callback +		function="WMap.Landmark"/>      </combo_box>      <icon       color="0.5 0 0 1" diff --git a/indra/newview/skins/default/xui/en/panel_landmarks.xml b/indra/newview/skins/default/xui/en/panel_landmarks.xml index f05684db10..4b91dc6294 100644 --- a/indra/newview/skins/default/xui/en/panel_landmarks.xml +++ b/indra/newview/skins/default/xui/en/panel_landmarks.xml @@ -63,7 +63,7 @@               left="0"               mouse_opaque="true"               name="my_inventory_list" -             start_folder="INVENTORY" +             start_folder="My Inventory"               width="380"/>            </accordion_tab>            <accordion_tab diff --git a/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml b/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml new file mode 100644 index 0000000000..f511ec0d6f --- /dev/null +++ b/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml @@ -0,0 +1,81 @@ +<?xml version="1.0" encoding="utf-8" standalone="yes" ?> +<panel name="Outfits"  +	  bottom="0"  +	  height="326"  +	  left="0"  +	  width="310" +	  border="true" +	  follows="left|top|right|bottom"> +	 <inventory_panel  +	 	 allow_multi_select="true"  +		 border="true"  +		 bottom="0" +	     follows="left|top|right|bottom"  +		 height="326"  +		 left="0"  +		 mouse_opaque="true" +	     name="outfits_list" +		 width="310" +		 start_folder="My Outfits"/> +	<button bottom="0" +		 halign="center" +		 height="16" +		 label=">" +		 enabled="false" +	     mouse_opaque="false" +		 name="selector" +		 width="20" +		 left="0" +		 visible="false" +	     follows="right|bottom" +		 tool_tip="View outfit properties"/> +    <panel +     background_visible="true" +     bevel_style="none" +     bottom="0" +     follows="left|right|bottom" +     height="30" +     layout="bottomleft" +     left="0" +	 visible="true" +     name="bottom_panel" +     width="310"> +        <button +         follows="bottom|left" +         tool_tip="Show additional options" +         height="18" +         image_disabled="OptionsMenu_Disabled" +         image_selected="OptionsMenu_Press" +         image_unselected="OptionsMenu_Off" +         layout="topleft" +         left="10" +         name="options_gear_btn" +         picture_style="true" +         top="6" +         width="18" /> +        <button +         follows="bottom|left" +         height="18" +         image_selected="AddItem_Press" +         image_unselected="AddItem_Off" +         image_disabled="AddItem_Disabled" +         layout="topleft" +         left_pad="5" +         name="add_btn" +         picture_style="true" +         tool_tip="Add new item" +         width="18" /> +        <dnd_button +         follows="bottom|right" +         height="18" +         image_selected="TrashItem_Press" +         image_unselected="TrashItem_Off" +         layout="topleft" +         right="-5" +         name="trash_btn" +         picture_style="true" +         tool_tip="Remove selected item" +         top="6" +         width="18" /> +    </panel> +</panel> diff --git a/indra/newview/skins/default/xui/en/panel_outfits_inventory_gear_default.xml b/indra/newview/skins/default/xui/en/panel_outfits_inventory_gear_default.xml new file mode 100644 index 0000000000..c8c79f8761 --- /dev/null +++ b/indra/newview/skins/default/xui/en/panel_outfits_inventory_gear_default.xml @@ -0,0 +1,42 @@ +<?xml version="1.0" encoding="utf-8" standalone="yes" ?> +<menu + bottom="806" + layout="topleft" + left="0" + mouse_opaque="false" + name="menu_gear_default" + visible="false"> +    <menu_item_call +     label="New Outfit" +     layout="topleft" +     name="new"> +        <on_click +         function="panel_outfits_inventory_gear_default.Custom.Action" +         parameter="new" /> +        <on_enable +		 function="panel_outfits_inventory_gear_default.Enable" +		 parameter="new" /> +    </menu_item_call> +    <menu_item_call +     label="Wear Outfit" +     layout="topleft" +     name="wear"> +        <on_click +         function="panel_outfits_inventory_gear_default.Custom.Action" +         parameter="wear" /> +        <on_enable +		 function="panel_outfits_inventory_gear_default.Enable" +		 parameter="wear" /> +    </menu_item_call> +    <menu_item_call +     label="Delete Outfit" +     layout="topleft" +     name="delete"> +        <on_click +         function="panel_outfits_inventory_gear_default.Custom.Action" +         parameter="delete" /> +        <on_enable +		 function="panel_outfits_inventory_gear_default.Enable" +		 parameter="delete" /> +    </menu_item_call> +</menu> diff --git a/indra/newview/skins/default/xui/en/panel_side_tray.xml b/indra/newview/skins/default/xui/en/panel_side_tray.xml index a419a02d75..d02354a647 100644 --- a/indra/newview/skins/default/xui/en/panel_side_tray.xml +++ b/indra/newview/skins/default/xui/en/panel_side_tray.xml @@ -120,9 +120,9 @@      background_visible="true"    >        <panel -        class="panel_appearance" -        name="panel_appearance" -        filename="panel_appearance.xml" +        class="sidepanel_appearance" +        name="sidepanel_appearance" +        filename="sidepanel_appearance.xml"          label="Edit Appearance"          font="SansSerifBold"        /> diff --git a/indra/newview/skins/default/xui/en/sidepanel_appearance.xml b/indra/newview/skins/default/xui/en/sidepanel_appearance.xml new file mode 100644 index 0000000000..2ce156cfda --- /dev/null +++ b/indra/newview/skins/default/xui/en/sidepanel_appearance.xml @@ -0,0 +1,104 @@ +<?xml version="1.0" encoding="utf-8" standalone="yes" ?> +<panel +	  background_visible="true" +	  follows="all" +	  height="400" +	  label="Appearance" +	  layout="topleft" +	  min_height="350" +	  min_width="240" +	  name="appearance panel" +	  width="333"> +     <string +		 name="looks_tab_title" +		 value="Outfits" /> +     <panel +		 left="5" width="320" height="55" +		 background_visible="true" +		 background_opaque="false" +		 bg_alpha_color="0.2 0.2 0.2 1.0" +		 name="panel_currentlook" +		 follows="left|top|right"> +		<text +			 top="-5" width="200" left="5" height="10" follows="left|right|top" +        	 font="SansSerif" text_color="LtGray" word_wrap="true" +        	 mouse_opaque="false" name="currentlook_title"> +					Current Outfit +    	</text> +  		<text +			 top="-30" left="8" height="10" follows="left|right|top" +      		 font="SansSerifBold" text_color="white" word_wrap="true" +      		 mouse_opaque="false" name="currentlook_name" > +					MyOutfit +  		</text> +  	    <button +  	     	 follows="left|right|top" +  	     	 font="SansSerif" +  	     	 top="28" right="-105" width="60" height="20" +  	     	 layout="topleft" +  		 	 label="Edit" +  	     	 name="editappearance_btn"/> +	</panel> + +    <filter_editor +  	     follows="left|top|right" +  	     font="SansSerif" +  	     label="Filter" +  	     layout="topleft" +  	     left="15"  +		 width="313" +		 height="20" +  	     name="Filter" /> +    <panel +   	     class="panel_outfits_inventory" +   	     filename="panel_outfits_inventory.xml" + 	     name="panel_outfits_inventory" +  	     follows="all" +  	     height="271" +  	     halign="center" +  	     layout="topleft" +  	     left="10" +  	     top_pad="19" +  	     width="313" /> +    <button +  	     follows="bottom|left" +  	     font="SansSerifSmallBold" +  	     height="25" +  	     label="Wear" +  	     layout="topleft" +  	     left="10" +  	     name="wear_btn" +     	 top_pad="0" +       	 width="80" /> +    <button +    	 follows="bottom|left" +  	     font="SansSerifSmallBold" +  	     height="25" +  	     label="New Outfit" +  	     layout="topleft" +  	     left_pad="0" +  	     name="newlook_btn" +  	     top_delta="0" +   	     width="90" /> + +	<panel +       	 class="panel_look_info" +       	 filename="panel_look_info.xml" +       	 follows="all" +       	 layout="topleft" +       	 left="0" +       	 name="panel_look_info" +       	 top="-200" +       	 visible="false" /> + +	<panel +	   	 class="panel_edit_wearable" +	   	 filename="panel_edit_wearable.xml" +	   	 follows="all" +	   	 layout="topleft" +	   	 left="0" +	   	 name="panel_edit_wearable" +	   	 top="-200" +	   	 visible="false" +	   	 width="333" /> +</panel> diff --git a/indra/newview/skins/default/xui/es/panel_edit_profile.xml b/indra/newview/skins/default/xui/es/panel_edit_profile.xml index c12dd8d58c..bcf4128e01 100644 --- a/indra/newview/skins/default/xui/es/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/es/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Residente" /> -   <string name="AcctTypeTrial" -    value="Prueba" /> -   <string name="AcctTypeCharterMember" -    value="Miembro fundador" /> -   <string name="AcctTypeEmployee" -    value="Empleado de Linden Lab" /> -   <string name="PaymentInfoUsed" -    value="Ha usado una forma de pago" /> -   <string name="PaymentInfoOnFile" -    value="Hay infor. de la forma de pago" /> -   <string name="NoPaymentInfoOnFile" -    value="Sin infor. de la forma de pago" /> -   <string name="AgeVerified" -    value="Edad verificada" /> -   <string name="NotAgeVerified" -    value="Edad no verificada" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=es -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Compañero/a:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Mensaje en el estado ocupado: -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Residente" />
 +   <string name="AcctTypeTrial"
 +    value="Prueba" />
 +   <string name="AcctTypeCharterMember"
 +    value="Miembro fundador" />
 +   <string name="AcctTypeEmployee"
 +    value="Empleado de Linden Lab" />
 +   <string name="PaymentInfoUsed"
 +    value="Ha usado una forma de pago" />
 +   <string name="PaymentInfoOnFile"
 +    value="Hay infor. de la forma de pago" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Sin infor. de la forma de pago" />
 +   <string name="AgeVerified"
 +    value="Edad verificada" />
 +   <string name="NotAgeVerified"
 +    value="Edad no verificada" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=es
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Compañero/a:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Mensaje en el estado ocupado:
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/skins/default/xui/it/panel_edit_profile.xml b/indra/newview/skins/default/xui/it/panel_edit_profile.xml index 33f3c367c2..0eba7bf3b6 100644 --- a/indra/newview/skins/default/xui/it/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/it/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Residente" /> -   <string name="AcctTypeTrial" -    value="Prova" /> -   <string name="AcctTypeCharterMember" -    value="Membro privilegiato" /> -   <string name="AcctTypeEmployee" -    value="Impiegato della Linden Lab" /> -   <string name="PaymentInfoUsed" -    value="Info. di pagamento usate" /> -   <string name="PaymentInfoOnFile" -    value="Info. di pagamento in archivio" /> -   <string name="NoPaymentInfoOnFile" -    value="Nessuna info. di pagamento" /> -   <string name="AgeVerified" -    value="Età verificata" /> -   <string name="NotAgeVerified" -    value="Età non verificata" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=it -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Partner:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Risposta agli IM quando sono in 'Occupato': -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Residente" />
 +   <string name="AcctTypeTrial"
 +    value="Prova" />
 +   <string name="AcctTypeCharterMember"
 +    value="Membro privilegiato" />
 +   <string name="AcctTypeEmployee"
 +    value="Impiegato della Linden Lab" />
 +   <string name="PaymentInfoUsed"
 +    value="Info. di pagamento usate" />
 +   <string name="PaymentInfoOnFile"
 +    value="Info. di pagamento in archivio" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Nessuna info. di pagamento" />
 +   <string name="AgeVerified"
 +    value="Età verificata" />
 +   <string name="NotAgeVerified"
 +    value="Età non verificata" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=it
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Partner:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Risposta agli IM quando sono in 'Occupato':
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/skins/default/xui/nl/panel_edit_profile.xml b/indra/newview/skins/default/xui/nl/panel_edit_profile.xml index 172395e20a..00f8c087de 100644 --- a/indra/newview/skins/default/xui/nl/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/nl/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Inwoner" /> -   <string name="AcctTypeTrial" -    value="Proef" /> -   <string name="AcctTypeCharterMember" -    value="Charter lid" /> -   <string name="AcctTypeEmployee" -    value="Linden Lab werknemer" /> -   <string name="PaymentInfoUsed" -    value="Betalingsinformatie gebruikt" /> -   <string name="PaymentInfoOnFile" -    value="Betalingsinformatie aanwezig" /> -   <string name="NoPaymentInfoOnFile" -    value="Geen betalingsinfo aanwezig" /> -   <string name="AgeVerified" -    value="Leeftijd geverifieerd" /> -   <string name="NotAgeVerified" -    value="Leeftijd niet geverifieerd" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=nl -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Partner:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Antwoord bij Niet Storen: -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Inwoner" />
 +   <string name="AcctTypeTrial"
 +    value="Proef" />
 +   <string name="AcctTypeCharterMember"
 +    value="Charter lid" />
 +   <string name="AcctTypeEmployee"
 +    value="Linden Lab werknemer" />
 +   <string name="PaymentInfoUsed"
 +    value="Betalingsinformatie gebruikt" />
 +   <string name="PaymentInfoOnFile"
 +    value="Betalingsinformatie aanwezig" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Geen betalingsinfo aanwezig" />
 +   <string name="AgeVerified"
 +    value="Leeftijd geverifieerd" />
 +   <string name="NotAgeVerified"
 +    value="Leeftijd niet geverifieerd" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=nl
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Partner:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Antwoord bij Niet Storen:
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/skins/default/xui/pl/panel_edit_profile.xml b/indra/newview/skins/default/xui/pl/panel_edit_profile.xml index 97fa3118f8..e449a92d7e 100644 --- a/indra/newview/skins/default/xui/pl/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/pl/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Rezydent" /> -   <string name="AcctTypeTrial" -    value="Próbne" /> -   <string name="AcctTypeCharterMember" -    value="Członek-zalożyciel" /> -   <string name="AcctTypeEmployee" -    value="Pracownik Linden Lab" /> -   <string name="PaymentInfoUsed" -    value="Dane Konta Używane" /> -   <string name="PaymentInfoOnFile" -    value="Dane Konta Dostępne" /> -   <string name="NoPaymentInfoOnFile" -    value="Brak Danych Konta" /> -   <string name="AgeVerified" -    value="Wiek Zweryfikowany" /> -   <string name="NotAgeVerified" -    value="Brak Weryfikacji Wieku" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=pl -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Partner:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Pracuś Mówi: -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Rezydent" />
 +   <string name="AcctTypeTrial"
 +    value="Próbne" />
 +   <string name="AcctTypeCharterMember"
 +    value="Członek-zalożyciel" />
 +   <string name="AcctTypeEmployee"
 +    value="Pracownik Linden Lab" />
 +   <string name="PaymentInfoUsed"
 +    value="Dane Konta Używane" />
 +   <string name="PaymentInfoOnFile"
 +    value="Dane Konta Dostępne" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Brak Danych Konta" />
 +   <string name="AgeVerified"
 +    value="Wiek Zweryfikowany" />
 +   <string name="NotAgeVerified"
 +    value="Brak Weryfikacji Wieku" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=pl
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Partner:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Pracuś Mówi:
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/skins/default/xui/pt/panel_edit_profile.xml b/indra/newview/skins/default/xui/pt/panel_edit_profile.xml index a989cab167..e97e77cfe6 100644 --- a/indra/newview/skins/default/xui/pt/panel_edit_profile.xml +++ b/indra/newview/skins/default/xui/pt/panel_edit_profile.xml @@ -1,45 +1,45 @@ -<?xml version="1.0" encoding="utf-8" standalone="yes" ?> -<panel name="edit_profile_panel"> -   <string name="CaptionTextAcctInfo"> -       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION] -   </string> -   <string name="AcctTypeResident" -    value="Residente" /> -   <string name="AcctTypeTrial" -    value="Teste" /> -   <string name="AcctTypeCharterMember" -    value="Estatuto do membro" /> -   <string name="AcctTypeEmployee" -    value="Contratado da Linden Lab" /> -   <string name="PaymentInfoUsed" -    value="Infor. de pagamento utilizadas" /> -   <string name="PaymentInfoOnFile" -    value="Infor. de pagamento no arquivo" /> -   <string name="NoPaymentInfoOnFile" -    value="Sem infor. de pagamento no arquivo" /> -   <string name="AgeVerified" -    value="Idade Verificada" /> -   <string name="NotAgeVerified" -    value="Idade não Verificada" /> -   <string name="partner_edit_link_url"> -       http://www.secondlife.com/account/partners.php?lang=pt -   </string> -    <panel name="scroll_content_panel"> -    <panel name="data_panel" > -     <panel name="lifes_images_panel"> -          <panel name="second_life_image_panel"> -              <text name="second_life_photo_title_text"> -			[SECOND_LIFE]: -              </text> -          </panel> -      </panel> -        <text name="title_partner_text" value="Parceiro:"/> -        <panel name="partner_data_panel"> -            <text name="partner_text" value="[FIRST] [LAST]"/> -         </panel> -      <text name="text_box3"> -	Resposta no Modo Ocupado: -      </text> -    </panel> -    </panel> -</panel> +<?xml version="1.0" encoding="utf-8" standalone="yes" ?>
 +<panel name="edit_profile_panel">
 +   <string name="CaptionTextAcctInfo">
 +       [ACCTTYPE] [PAYMENTINFO] [AGEVERIFICATION]
 +   </string>
 +   <string name="AcctTypeResident"
 +    value="Residente" />
 +   <string name="AcctTypeTrial"
 +    value="Teste" />
 +   <string name="AcctTypeCharterMember"
 +    value="Estatuto do membro" />
 +   <string name="AcctTypeEmployee"
 +    value="Contratado da Linden Lab" />
 +   <string name="PaymentInfoUsed"
 +    value="Infor. de pagamento utilizadas" />
 +   <string name="PaymentInfoOnFile"
 +    value="Infor. de pagamento no arquivo" />
 +   <string name="NoPaymentInfoOnFile"
 +    value="Sem infor. de pagamento no arquivo" />
 +   <string name="AgeVerified"
 +    value="Idade Verificada" />
 +   <string name="NotAgeVerified"
 +    value="Idade não Verificada" />
 +   <string name="partner_edit_link_url">
 +       http://www.secondlife.com/account/partners.php?lang=pt
 +   </string>
 +    <panel name="scroll_content_panel">
 +    <panel name="data_panel" >
 +     <panel name="lifes_images_panel">
 +          <panel name="second_life_image_panel">
 +              <text name="second_life_photo_title_text">
 +			[SECOND_LIFE]:
 +              </text>
 +          </panel>
 +      </panel>
 +        <text name="title_partner_text" value="Parceiro:"/>
 +        <panel name="partner_data_panel">
 +            <text name="partner_text" value="[FIRST] [LAST]"/>
 +         </panel>
 +      <text name="text_box3">
 +	Resposta no Modo Ocupado:
 +      </text>
 +    </panel>
 +    </panel>
 +</panel>
 diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py index 64cfdf2704..4193343d64 100755 --- a/indra/newview/viewer_manifest.py +++ b/indra/newview/viewer_manifest.py @@ -243,7 +243,7 @@ class WindowsManifest(ViewerManifest):              # Get kdu dll, continue if missing.              try: -                self.path('%s/llkdu.dll' % self.args['configuration'], dst='llkdu.dll') +                self.path('llkdu.dll', dst='llkdu.dll')              except RuntimeError:                  print "Skipping llkdu.dll" | 
