diff options
-rw-r--r-- | ChangeLog.txt | 199 | ||||
-rw-r--r-- | linden/indra/llinventory/llinventory.cpp | 138 | ||||
-rw-r--r-- | linden/indra/llinventory/llinventory.h | 12 | ||||
-rw-r--r-- | linden/indra/llinventory/llinventorytype.h | 86 | ||||
-rw-r--r-- | linden/indra/llinventory/llwearabletype.h | 54 | ||||
-rw-r--r-- | linden/indra/llui/llcombobox.cpp | 5 | ||||
-rw-r--r-- | linden/indra/newview/llfolderview.cpp | 45 | ||||
-rw-r--r-- | linden/indra/newview/llfolderview.h | 4 | ||||
-rw-r--r-- | linden/indra/newview/llinventorybridge.cpp | 1 | ||||
-rw-r--r-- | linden/indra/newview/llinventorybridge.h | 11 | ||||
-rw-r--r-- | linden/indra/newview/llinventoryview.cpp | 520 | ||||
-rw-r--r-- | linden/indra/newview/llinventoryview.h | 7 | ||||
-rw-r--r-- | linden/indra/newview/llpanelinventory.cpp | 1 | ||||
-rw-r--r-- | linden/indra/newview/llwearable.h | 20 | ||||
-rw-r--r-- | linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml | 56 | ||||
-rw-r--r-- | linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml | 227 |
16 files changed, 1132 insertions, 254 deletions
diff --git a/ChangeLog.txt b/ChangeLog.txt index 9b4fe7d..6b75515 100644 --- a/ChangeLog.txt +++ b/ChangeLog.txt | |||
@@ -36,6 +36,116 @@ | |||
36 | Backported from LL's 1.22 RC3. | 36 | Backported from LL's 1.22 RC3. |
37 | 37 | ||
38 | 38 | ||
39 | 2008-12-10 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
40 | |||
41 | * linden/indra/newview/llinventoryview.cpp: | ||
42 | Use NType to find inventory icon name. | ||
43 | * linden/indra/newview/llinventoryview.h: | ||
44 | Ditto. | ||
45 | |||
46 | |||
47 | * linden/indra/newview/llinventoryview.cpp: | ||
48 | Clearing search shouldn't clear filter type. | ||
49 | |||
50 | |||
51 | 2008-12-09 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
52 | |||
53 | * linden/indra/newview/llinventoryview.cpp: | ||
54 | Start fetching inventory when quick filter changes. | ||
55 | |||
56 | |||
57 | * linden/indra/newview/llinventoryview.cpp: | ||
58 | Refresh filter text when quick filter changes. | ||
59 | |||
60 | |||
61 | * linden/indra/newview/llfolderview.cpp: | ||
62 | Refactored; added LLInventoryFilter::rebuildFilterText(). | ||
63 | * linden/indra/newview/llfolderview.h: | ||
64 | Ditto. | ||
65 | |||
66 | |||
67 | * linden/indra/newview/llfolderview.cpp: | ||
68 | Updated Inventory window filter text generation. | ||
69 | It was putting the wrong types in the title when | ||
70 | filtering. [#25] | ||
71 | |||
72 | |||
73 | 2008-12-08 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
74 | |||
75 | * linden/indra/newview/llinventoryview.cpp: | ||
76 | Hooked up Body Parts quickfilter and checkbox. | ||
77 | |||
78 | |||
79 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
80 | Added Quick Filter item for Body Parts. | ||
81 | |||
82 | |||
83 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml: | ||
84 | Added Show Filters checkbox for Body Parts. | ||
85 | |||
86 | |||
87 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml: | ||
88 | Converted Show Filters window to relative positioning. | ||
89 | |||
90 | |||
91 | * linden/indra/newview/llfolderview.cpp: | ||
92 | Inventory filtering is now done by NType. | ||
93 | |||
94 | |||
95 | * linden/indra/newview/llinventorybridge.cpp: | ||
96 | LLInvFVBridge and derived classes have NTypes. | ||
97 | * linden/indra/newview/llinventorybridge.h: | ||
98 | Ditto. | ||
99 | * linden/indra/newview/llpanelinventory.cpp: | ||
100 | Ditto. | ||
101 | |||
102 | |||
103 | * linden/indra/newview/llfolderview.h: | ||
104 | Added LLFolderViewEventListener::getNInventoryType() | ||
105 | Pure virtual method, overridden in derived classes. | ||
106 | |||
107 | |||
108 | * linden/indra/newview/llinventoryview.cpp: | ||
109 | LLInventoryView uses new inventory type. | ||
110 | |||
111 | |||
112 | * linden/indra/llinventory/llinventory.cpp: | ||
113 | Recalculate ntype when changing type or flags. | ||
114 | |||
115 | |||
116 | * linden/indra/llinventory/llinventory.cpp: | ||
117 | Added LLInventoryItem::recalcNInventoryType(). | ||
118 | * linden/indra/llinventory/llinventory.h: | ||
119 | Ditto. | ||
120 | |||
121 | |||
122 | * linden/indra/llinventory/llinventory.cpp: | ||
123 | Added calc_ntype() function. | ||
124 | * linden/indra/llinventory/llinventory.h: | ||
125 | Ditto. | ||
126 | |||
127 | |||
128 | * linden/indra/llinventory/llwearabletype.h: | ||
129 | Moved enum EWearableType to its own file. | ||
130 | Was in newview/llwearable.h, now in llinventory/llwearabletype.h. | ||
131 | This allows it to be used in llinventory code. | ||
132 | * linden/indra/newview/llwearable.h: | ||
133 | Ditto. | ||
134 | |||
135 | |||
136 | 2008-12-07 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
137 | |||
138 | * linden/indra/llinventory/llinventory.cpp: | ||
139 | Added LLInventoryItem::mNInventoryType (new type) field. | ||
140 | Will always by NIT_NONE so far. | ||
141 | * linden/indra/llinventory/llinventory.h: | ||
142 | Ditto. | ||
143 | |||
144 | |||
145 | * linden/indra/llinventory/llinventorytype.h: | ||
146 | New bitfield enumerator for inventory types. | ||
147 | |||
148 | |||
39 | 2008-12-01 McCabe Maxsted <hakushakukun@gmail.com> | 149 | 2008-12-01 McCabe Maxsted <hakushakukun@gmail.com> |
40 | 150 | ||
41 | * linden/indra/newview/app_settings/settings.xml: | 151 | * linden/indra/newview/app_settings/settings.xml: |
@@ -82,6 +192,64 @@ | |||
82 | Switched Invite and Leave buttons in group panel. | 192 | Switched Invite and Leave buttons in group panel. |
83 | 193 | ||
84 | 194 | ||
195 | 2008-11-23 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
196 | |||
197 | * linden/indra/newview/llinventoryview.cpp: | ||
198 | Read filter labels from LLTrans, no hard-coding. | ||
199 | |||
200 | |||
201 | * linden/indra/newview/skins/default/xui/en-us/strings.xml: | ||
202 | Defined strings for filter types (to allow translation). | ||
203 | |||
204 | |||
205 | 2008-11-22 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
206 | |||
207 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml: | ||
208 | Cleaned up Show Filters floater XML. | ||
209 | |||
210 | |||
211 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
212 | Added separators to Quick Filter. | ||
213 | |||
214 | |||
215 | * linden/indra/llui/llcombobox.cpp: | ||
216 | Combobox widget now supports separators in XUI. | ||
217 | |||
218 | |||
219 | * linden/indra/newview/llinventoryview.cpp: | ||
220 | Renamed "Clothing" filter to "Clothing / Body Parts". | ||
221 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
222 | Ditto. | ||
223 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml: | ||
224 | Ditto. | ||
225 | |||
226 | |||
227 | * linden/indra/newview/llinventoryview.cpp: | ||
228 | Renamed "Show All Items" filter to "All Types". | ||
229 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
230 | Ditto. | ||
231 | |||
232 | |||
233 | * linden/indra/newview/llinventoryview.cpp: | ||
234 | Renamed "Show All Items" to "All Types". | ||
235 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
236 | Ditto. | ||
237 | |||
238 | |||
239 | * linden/indra/newview/llinventoryview.cpp: | ||
240 | Bogus quick filter strings should be ignored. | ||
241 | |||
242 | |||
243 | * linden/indra/newview/llinventoryview.cpp: | ||
244 | Disabled testing output when changing quick filter. | ||
245 | |||
246 | |||
247 | * linden/indra/newview/llinventoryview.cpp: | ||
248 | Quick Filter combo box refreshes properly. | ||
249 | * linden/indra/newview/llinventoryview.h: | ||
250 | Ditto. | ||
251 | |||
252 | |||
85 | 2008-11-22 McCabe Maxsted <hakushakukun@gmail.com> | 253 | 2008-11-22 McCabe Maxsted <hakushakukun@gmail.com> |
86 | 254 | ||
87 | * linden\indra\newview\skins\default\colors_base.xml: | 255 | * linden\indra\newview\skins\default\colors_base.xml: |
@@ -116,6 +284,37 @@ | |||
116 | Friends show yellow in minimap (VWR-3336). | 284 | Friends show yellow in minimap (VWR-3336). |
117 | 285 | ||
118 | 286 | ||
287 | 2008-11-11 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
288 | |||
289 | * linden/indra/newview/llinventoryview.cpp: | ||
290 | Show Filters window refreshes properly. | ||
291 | |||
292 | |||
293 | 2008-11-08 Jacek Antonelli <jacek.antonelli@gmail.com> | ||
294 | |||
295 | * linden/indra/newview/llinventoryview.cpp: | ||
296 | Added 'Custom' filter option (opens filters window). | ||
297 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
298 | Ditto. | ||
299 | |||
300 | |||
301 | * linden/indra/newview/llinventoryview.cpp: | ||
302 | Quick Filter works, but is a bit rough. | ||
303 | It doesn't refresh its display when you change tabs, | ||
304 | and the Show Filters window doesn't refresh either. | ||
305 | |||
306 | |||
307 | * linden/indra/newview/llinventoryview.cpp: | ||
308 | Added commit callback for Quick Filter. | ||
309 | * linden/indra/newview/llinventoryview.h: | ||
310 | Ditto. | ||
311 | |||
312 | |||
313 | * linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml: | ||
314 | Added XUI for the Quick Filter combo box. | ||
315 | |||
316 | |||
317 | |||
119 | 2008-10-18 McCabe Maxsted <hakushakukun@gmail.com> | 318 | 2008-10-18 McCabe Maxsted <hakushakukun@gmail.com> |
120 | 319 | ||
121 | * linden\indra\newview\skins\default\xui\en-us\menu_viewer.xml: | 320 | * linden\indra\newview\skins\default\xui\en-us\menu_viewer.xml: |
diff --git a/linden/indra/llinventory/llinventory.cpp b/linden/indra/llinventory/llinventory.cpp index 457a0cb..0a8a1fb 100644 --- a/linden/indra/llinventory/llinventory.cpp +++ b/linden/indra/llinventory/llinventory.cpp | |||
@@ -70,6 +70,116 @@ const U8 TASK_INVENTORY_ASSET_KEY = 1; | |||
70 | const LLUUID MAGIC_ID("3c115e51-04f4-523c-9fa6-98aff1034730"); | 70 | const LLUUID MAGIC_ID("3c115e51-04f4-523c-9fa6-98aff1034730"); |
71 | 71 | ||
72 | 72 | ||
73 | /** | ||
74 | * @brief Return the equivalent new inventory type. | ||
75 | * | ||
76 | * Takes an inventory type, asset type, and inventory flags, | ||
77 | * and returns the equivalent LLInventory::NType. | ||
78 | * | ||
79 | * For example, an inventory type of IT_WEARABLE, asset type | ||
80 | * of AT_BODYPART, and flags indicated WT_SHAPE, would be | ||
81 | * converted to NIT_SHAPE. | ||
82 | * | ||
83 | * Returns the most specific type that can be determined, | ||
84 | * or NIT_NONE if no type could be determined. | ||
85 | * | ||
86 | */ | ||
87 | LLInventoryType::NType calc_ntype( | ||
88 | LLInventoryType::EType inv_type, | ||
89 | LLAssetType::EType asset_type, | ||
90 | U32 flags ) | ||
91 | { | ||
92 | switch( inv_type ) | ||
93 | { | ||
94 | |||
95 | // WEARABLES | ||
96 | case LLInventoryType::IT_WEARABLE: | ||
97 | { | ||
98 | switch( asset_type ) | ||
99 | { | ||
100 | // BODY PARTS | ||
101 | case LLAssetType::AT_BODYPART: | ||
102 | { | ||
103 | switch( flags & LLInventoryItem::II_FLAGS_WEARABLES_MASK ) | ||
104 | { | ||
105 | case WT_SHAPE: return LLInventoryType::NIT_SHAPE; | ||
106 | case WT_SKIN: return LLInventoryType::NIT_SKIN; | ||
107 | case WT_HAIR: return LLInventoryType::NIT_HAIR; | ||
108 | case WT_EYES: return LLInventoryType::NIT_EYES; | ||
109 | default: return LLInventoryType::NIT_BODYPART; | ||
110 | } | ||
111 | } | ||
112 | |||
113 | // CLOTHING | ||
114 | case LLAssetType::AT_CLOTHING: | ||
115 | { | ||
116 | switch( flags & LLInventoryItem::II_FLAGS_WEARABLES_MASK ) | ||
117 | { | ||
118 | case WT_SHIRT: return LLInventoryType::NIT_SHIRT; | ||
119 | case WT_PANTS: return LLInventoryType::NIT_PANTS; | ||
120 | case WT_SHOES: return LLInventoryType::NIT_SHOES; | ||
121 | case WT_SOCKS: return LLInventoryType::NIT_SOCKS; | ||
122 | case WT_JACKET: return LLInventoryType::NIT_JACKET; | ||
123 | case WT_GLOVES: return LLInventoryType::NIT_GLOVES; | ||
124 | case WT_UNDERSHIRT: return LLInventoryType::NIT_UNDERSHIRT; | ||
125 | case WT_UNDERPANTS: return LLInventoryType::NIT_UNDERPANTS; | ||
126 | case WT_SKIRT: return LLInventoryType::NIT_SKIRT; | ||
127 | default: return LLInventoryType::NIT_CLOTHING; | ||
128 | } | ||
129 | } | ||
130 | default: | ||
131 | return LLInventoryType::NIT_WEARABLE; | ||
132 | } | ||
133 | } | ||
134 | |||
135 | // TEXTURES | ||
136 | case LLInventoryType::IT_TEXTURE: | ||
137 | return LLInventoryType::NIT_TEXTURE; | ||
138 | |||
139 | // SNAPSHOTS | ||
140 | case LLInventoryType::IT_SNAPSHOT: | ||
141 | return LLInventoryType::NIT_SNAPSHOT; | ||
142 | |||
143 | // CALLING CARDS | ||
144 | case LLInventoryType::IT_CALLINGCARD: | ||
145 | return LLInventoryType::NIT_CALLCARD; | ||
146 | |||
147 | // LANDMARKS | ||
148 | case LLInventoryType::IT_LANDMARK: | ||
149 | return LLInventoryType::NIT_LANDMARK; | ||
150 | |||
151 | // SOUNDS | ||
152 | case LLInventoryType::IT_SOUND: | ||
153 | return LLInventoryType::NIT_SOUND; | ||
154 | |||
155 | // ANIMATIONS | ||
156 | case LLInventoryType::IT_ANIMATION: | ||
157 | return LLInventoryType::NIT_ANIMATION; | ||
158 | |||
159 | // GESTURES | ||
160 | case LLInventoryType::IT_GESTURE: | ||
161 | return LLInventoryType::NIT_GESTURE; | ||
162 | |||
163 | // NOTECARDS | ||
164 | case LLInventoryType::IT_NOTECARD: | ||
165 | return LLInventoryType::NIT_NOTECARD; | ||
166 | |||
167 | // SCRIPTS | ||
168 | case LLInventoryType::IT_LSL: | ||
169 | return LLInventoryType::NIT_SCRIPT_LSL2; | ||
170 | |||
171 | // OBJECTS | ||
172 | case LLInventoryType::IT_OBJECT: | ||
173 | case LLInventoryType::IT_ATTACHMENT: | ||
174 | return LLInventoryType::NIT_OBJECT; | ||
175 | |||
176 | // UNKNOWN TYPE! | ||
177 | default: | ||
178 | return LLInventoryType::NIT_NONE; | ||
179 | } | ||
180 | } | ||
181 | |||
182 | |||
73 | ///---------------------------------------------------------------------------- | 183 | ///---------------------------------------------------------------------------- |
74 | /// Class LLInventoryObject | 184 | /// Class LLInventoryObject |
75 | ///---------------------------------------------------------------------------- | 185 | ///---------------------------------------------------------------------------- |
@@ -287,11 +397,13 @@ LLInventoryItem::LLInventoryItem( | |||
287 | mDescription(desc), | 397 | mDescription(desc), |
288 | mSaleInfo(sale_info), | 398 | mSaleInfo(sale_info), |
289 | mInventoryType(inv_type), | 399 | mInventoryType(inv_type), |
400 | mNInventoryType(LLInventoryType::NIT_NONE), | ||
290 | mFlags(flags), | 401 | mFlags(flags), |
291 | mCreationDate(creation_date_utc) | 402 | mCreationDate(creation_date_utc) |
292 | { | 403 | { |
293 | LLStringUtil::replaceNonstandardASCII(mDescription, ' '); | 404 | LLStringUtil::replaceNonstandardASCII(mDescription, ' '); |
294 | LLStringUtil::replaceChar(mDescription, '|', ' '); | 405 | LLStringUtil::replaceChar(mDescription, '|', ' '); |
406 | recalcNInventoryType(); | ||
295 | } | 407 | } |
296 | 408 | ||
297 | LLInventoryItem::LLInventoryItem() : | 409 | LLInventoryItem::LLInventoryItem() : |
@@ -301,6 +413,7 @@ LLInventoryItem::LLInventoryItem() : | |||
301 | mDescription(), | 413 | mDescription(), |
302 | mSaleInfo(), | 414 | mSaleInfo(), |
303 | mInventoryType(LLInventoryType::IT_NONE), | 415 | mInventoryType(LLInventoryType::IT_NONE), |
416 | mNInventoryType(LLInventoryType::NIT_NONE), | ||
304 | mFlags(0), | 417 | mFlags(0), |
305 | mCreationDate(0) | 418 | mCreationDate(0) |
306 | { | 419 | { |
@@ -325,6 +438,7 @@ void LLInventoryItem::copyItem(const LLInventoryItem* other) | |||
325 | mDescription = other->mDescription; | 438 | mDescription = other->mDescription; |
326 | mSaleInfo = other->mSaleInfo; | 439 | mSaleInfo = other->mSaleInfo; |
327 | mInventoryType = other->mInventoryType; | 440 | mInventoryType = other->mInventoryType; |
441 | mNInventoryType = other->mNInventoryType; | ||
328 | mFlags = other->mFlags; | 442 | mFlags = other->mFlags; |
329 | mCreationDate = other->mCreationDate; | 443 | mCreationDate = other->mCreationDate; |
330 | } | 444 | } |
@@ -396,6 +510,12 @@ U32 LLInventoryItem::getCRC32() const | |||
396 | } | 510 | } |
397 | 511 | ||
398 | 512 | ||
513 | void LLInventoryItem::recalcNInventoryType() | ||
514 | { | ||
515 | setNInventoryType( calc_ntype(mInventoryType, mType, mFlags) ); | ||
516 | } | ||
517 | |||
518 | |||
399 | void LLInventoryItem::setDescription(const std::string& d) | 519 | void LLInventoryItem::setDescription(const std::string& d) |
400 | { | 520 | { |
401 | std::string new_desc(d); | 521 | std::string new_desc(d); |
@@ -412,14 +532,27 @@ void LLInventoryItem::setPermissions(const LLPermissions& perm) | |||
412 | mPermissions = perm; | 532 | mPermissions = perm; |
413 | } | 533 | } |
414 | 534 | ||
535 | void LLInventoryItem::setType(LLAssetType::EType type) | ||
536 | { | ||
537 | mType = type; | ||
538 | recalcNInventoryType(); | ||
539 | } | ||
540 | |||
415 | void LLInventoryItem::setInventoryType(LLInventoryType::EType inv_type) | 541 | void LLInventoryItem::setInventoryType(LLInventoryType::EType inv_type) |
416 | { | 542 | { |
417 | mInventoryType = inv_type; | 543 | mInventoryType = inv_type; |
544 | recalcNInventoryType(); | ||
545 | } | ||
546 | |||
547 | void LLInventoryItem::setNInventoryType(LLInventoryType::NType inv_type) | ||
548 | { | ||
549 | mNInventoryType = inv_type; | ||
418 | } | 550 | } |
419 | 551 | ||
420 | void LLInventoryItem::setFlags(U32 flags) | 552 | void LLInventoryItem::setFlags(U32 flags) |
421 | { | 553 | { |
422 | mFlags = flags; | 554 | mFlags = flags; |
555 | recalcNInventoryType(); | ||
423 | } | 556 | } |
424 | 557 | ||
425 | void LLInventoryItem::setCreationDate(time_t creation_date_utc) | 558 | void LLInventoryItem::setCreationDate(time_t creation_date_utc) |
@@ -443,6 +576,11 @@ LLInventoryType::EType LLInventoryItem::getInventoryType() const | |||
443 | return mInventoryType; | 576 | return mInventoryType; |
444 | } | 577 | } |
445 | 578 | ||
579 | LLInventoryType::NType LLInventoryItem::getNInventoryType() const | ||
580 | { | ||
581 | return mNInventoryType; | ||
582 | } | ||
583 | |||
446 | U32 LLInventoryItem::getFlags() const | 584 | U32 LLInventoryItem::getFlags() const |
447 | { | 585 | { |
448 | return mFlags; | 586 | return mFlags; |
diff --git a/linden/indra/llinventory/llinventory.h b/linden/indra/llinventory/llinventory.h index d3cce6b..c573f74 100644 --- a/linden/indra/llinventory/llinventory.h +++ b/linden/indra/llinventory/llinventory.h | |||
@@ -42,6 +42,7 @@ | |||
42 | #include "llsaleinfo.h" | 42 | #include "llsaleinfo.h" |
43 | #include "llsd.h" | 43 | #include "llsd.h" |
44 | #include "lluuid.h" | 44 | #include "lluuid.h" |
45 | #include "llwearabletype.h" | ||
45 | #include "llxmlnode.h" | 46 | #include "llxmlnode.h" |
46 | 47 | ||
47 | // consts for Key field in the task inventory update message | 48 | // consts for Key field in the task inventory update message |
@@ -56,6 +57,10 @@ enum | |||
56 | }; | 57 | }; |
57 | 58 | ||
58 | 59 | ||
60 | LLInventoryType::NType calc_ntype( LLInventoryType::EType inv_type, | ||
61 | LLAssetType::EType asset_type, | ||
62 | U32 flags ); | ||
63 | |||
59 | 64 | ||
60 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 65 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
61 | // Class LLInventoryObject | 66 | // Class LLInventoryObject |
@@ -131,6 +136,7 @@ protected: | |||
131 | std::string mDescription; | 136 | std::string mDescription; |
132 | LLSaleInfo mSaleInfo; | 137 | LLSaleInfo mSaleInfo; |
133 | LLInventoryType::EType mInventoryType; | 138 | LLInventoryType::EType mInventoryType; |
139 | LLInventoryType::NType mNInventoryType; | ||
134 | U32 mFlags; | 140 | U32 mFlags; |
135 | time_t mCreationDate; // seconds from 1/1/1970, UTC | 141 | time_t mCreationDate; // seconds from 1/1/1970, UTC |
136 | 142 | ||
@@ -236,6 +242,7 @@ public: | |||
236 | const std::string& getDescription() const; | 242 | const std::string& getDescription() const; |
237 | const LLSaleInfo& getSaleInfo() const; | 243 | const LLSaleInfo& getSaleInfo() const; |
238 | LLInventoryType::EType getInventoryType() const; | 244 | LLInventoryType::EType getInventoryType() const; |
245 | LLInventoryType::NType getNInventoryType() const; | ||
239 | U32 getFlags() const; | 246 | U32 getFlags() const; |
240 | time_t getCreationDate() const; | 247 | time_t getCreationDate() const; |
241 | U32 getCRC32() const; // really more of a checksum. | 248 | U32 getCRC32() const; // really more of a checksum. |
@@ -246,7 +253,9 @@ public: | |||
246 | void setDescription(const std::string& new_desc); | 253 | void setDescription(const std::string& new_desc); |
247 | void setSaleInfo(const LLSaleInfo& sale_info); | 254 | void setSaleInfo(const LLSaleInfo& sale_info); |
248 | void setPermissions(const LLPermissions& perm); | 255 | void setPermissions(const LLPermissions& perm); |
256 | void setType(LLAssetType::EType type); | ||
249 | void setInventoryType(LLInventoryType::EType inv_type); | 257 | void setInventoryType(LLInventoryType::EType inv_type); |
258 | void setNInventoryType(LLInventoryType::NType inv_type); | ||
250 | void setFlags(U32 flags); | 259 | void setFlags(U32 flags); |
251 | void setCreationDate(time_t creation_date_utc); | 260 | void setCreationDate(time_t creation_date_utc); |
252 | 261 | ||
@@ -277,6 +286,9 @@ public: | |||
277 | LLSD asLLSD() const; | 286 | LLSD asLLSD() const; |
278 | bool fromLLSD(LLSD& sd); | 287 | bool fromLLSD(LLSD& sd); |
279 | 288 | ||
289 | private: | ||
290 | void recalcNInventoryType(); | ||
291 | |||
280 | }; | 292 | }; |
281 | 293 | ||
282 | BOOL item_dictionary_sort(LLInventoryItem* a,LLInventoryItem* b); | 294 | BOOL item_dictionary_sort(LLInventoryItem* a,LLInventoryItem* b); |
diff --git a/linden/indra/llinventory/llinventorytype.h b/linden/indra/llinventory/llinventorytype.h index 00a4d28..f228cd0 100644 --- a/linden/indra/llinventory/llinventorytype.h +++ b/linden/indra/llinventory/llinventorytype.h | |||
@@ -71,6 +71,92 @@ public: | |||
71 | IT_NONE = -1 | 71 | IT_NONE = -1 |
72 | }; | 72 | }; |
73 | 73 | ||
74 | |||
75 | /** | ||
76 | * @brief New enumerator for inventory types | ||
77 | * | ||
78 | * This is intended as a replacement to the above EType. | ||
79 | * EType will be phased out in favor of this enum. | ||
80 | * | ||
81 | * This enum acts as a bitfield, which This has several | ||
82 | * useful properties for filtering: | ||
83 | * | ||
84 | * 1. The inventory item's type can be compared by either | ||
85 | * equality or bitwise AND. Bitwise AND allows a quick | ||
86 | * check to see whether the type is one of multiple | ||
87 | * possible types. | ||
88 | * | ||
89 | * 2. It allows for a fast hierarchical organization, by | ||
90 | * defining a broad type (e.g. NIT_BODYPART) whose | ||
91 | * value is the bitwise OR-ing of several more specific | ||
92 | * sub-types (e.g. NIT_SKIN|NIT_HAIR|...). | ||
93 | * | ||
94 | */ | ||
95 | enum NType | ||
96 | { | ||
97 | /* No Type */ | ||
98 | NIT_NONE = 0x0000000, | ||
99 | |||
100 | /* Body Parts */ | ||
101 | NIT_SHAPE = 1 << 0, | ||
102 | NIT_SKIN = 1 << 1, | ||
103 | NIT_HAIR = 1 << 2, | ||
104 | NIT_EYES = 1 << 3, | ||
105 | NIT_BODYPART = 0x000000f, | ||
106 | |||
107 | /* Clothing */ | ||
108 | NIT_SHIRT = 1 << 4, | ||
109 | NIT_PANTS = 1 << 5, | ||
110 | NIT_SHOES = 1 << 6, | ||
111 | NIT_SOCKS = 1 << 7, | ||
112 | NIT_JACKET = 1 << 8, | ||
113 | NIT_GLOVES = 1 << 9, | ||
114 | NIT_UNDERSHIRT = 1 << 10, | ||
115 | NIT_UNDERPANTS = 1 << 11, | ||
116 | NIT_SKIRT = 1 << 12, | ||
117 | NIT_CLOTHING = 0x0001ff0, | ||
118 | |||
119 | /* Body Parts | Clothing */ | ||
120 | NIT_WEARABLE = 0x0001fff, | ||
121 | |||
122 | /* Images */ | ||
123 | NIT_TEXTURE = 1 << 13, | ||
124 | NIT_SNAPSHOT = 1 << 14, | ||
125 | NIT_IMAGE = 0x0006000, | ||
126 | |||
127 | /* Calling Cards */ | ||
128 | NIT_CALLCARD_OFF = 1 << 15, | ||
129 | NIT_CALLCARD_ON = 1 << 16, | ||
130 | NIT_CALLCARD = 0x0018000, | ||
131 | |||
132 | /* Landmarks */ | ||
133 | NIT_LANDMARK_UNUSED = 1 << 17, | ||
134 | NIT_LANDMARK_USED = 1 << 18, | ||
135 | NIT_LANDMARK = 0x0060000, | ||
136 | |||
137 | /* Sounds */ | ||
138 | NIT_SOUND = 1 << 19, | ||
139 | |||
140 | /* Animations */ | ||
141 | NIT_ANIMATION = 1 << 20, | ||
142 | |||
143 | /* Gestures */ | ||
144 | NIT_GESTURE = 1 << 21, | ||
145 | |||
146 | /* Notecards */ | ||
147 | NIT_NOTECARD = 1 << 22, | ||
148 | |||
149 | /* Scripts */ | ||
150 | NIT_SCRIPT_LSL2 = 1 << 23, | ||
151 | |||
152 | /* Objects */ | ||
153 | NIT_OBJECT = 1 << 24, | ||
154 | |||
155 | /* Bitwise OR-ing of all the above */ | ||
156 | NIT_ALL = 0x1ffffff, | ||
157 | }; | ||
158 | |||
159 | |||
74 | // machine transation between type and strings | 160 | // machine transation between type and strings |
75 | static EType lookup(const std::string& name); | 161 | static EType lookup(const std::string& name); |
76 | static const char* lookup(EType type); | 162 | static const char* lookup(EType type); |
diff --git a/linden/indra/llinventory/llwearabletype.h b/linden/indra/llinventory/llwearabletype.h new file mode 100644 index 0000000..b0a40b2 --- /dev/null +++ b/linden/indra/llinventory/llwearabletype.h | |||
@@ -0,0 +1,54 @@ | |||
1 | /** | ||
2 | * @file llwearable.h | ||
3 | * @brief EWearableType enum definition | ||
4 | * | ||
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | ||
6 | * | ||
7 | * Copyright (c) 2002-2008, Linden Research, Inc. | ||
8 | * | ||
9 | * Second Life Viewer Source Code | ||
10 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
11 | * to you under the terms of the GNU General Public License, version 2.0 | ||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 | ||
16 | * | ||
17 | * There are special exceptions to the terms and conditions of the GPL as | ||
18 | * it is applied to this Source Code. View the full text of the exception | ||
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception | ||
21 | * | ||
22 | * By copying, modifying or distributing this software, you acknowledge | ||
23 | * that you have read and understood your obligations described above, | ||
24 | * and agree to abide by those obligations. | ||
25 | * | ||
26 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
27 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
28 | * COMPLETENESS OR PERFORMANCE. | ||
29 | * $/LicenseInfo$ | ||
30 | */ | ||
31 | |||
32 | #ifndef LL_LLWEARABLETYPE_H | ||
33 | #define LL_LLWEARABLETYPE_H | ||
34 | |||
35 | enum EWearableType // If you change this, update LLWearable::getTypeName(), getTypeLabel(), and LLVOAvatar::getTEWearableType() | ||
36 | { | ||
37 | WT_SHAPE = 0, | ||
38 | WT_SKIN = 1, | ||
39 | WT_HAIR = 2, | ||
40 | WT_EYES = 3, | ||
41 | WT_SHIRT = 4, | ||
42 | WT_PANTS = 5, | ||
43 | WT_SHOES = 6, | ||
44 | WT_SOCKS = 7, | ||
45 | WT_JACKET = 8, | ||
46 | WT_GLOVES = 9, | ||
47 | WT_UNDERSHIRT = 10, | ||
48 | WT_UNDERPANTS = 11, | ||
49 | WT_SKIRT = 12, | ||
50 | WT_COUNT = 13, | ||
51 | WT_INVALID = 255 | ||
52 | }; | ||
53 | |||
54 | #endif // LL_LLWEARABLETYPE_H | ||
diff --git a/linden/indra/llui/llcombobox.cpp b/linden/indra/llui/llcombobox.cpp index 9a2e13b..cb9dd4e 100644 --- a/linden/indra/llui/llcombobox.cpp +++ b/linden/indra/llui/llcombobox.cpp | |||
@@ -194,6 +194,11 @@ LLView* LLComboBox::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory * | |||
194 | 194 | ||
195 | combo_box->add(label, LLSD(value) ); | 195 | combo_box->add(label, LLSD(value) ); |
196 | } | 196 | } |
197 | |||
198 | else if (child->hasName("separator")) | ||
199 | { | ||
200 | combo_box->addSeparator(); | ||
201 | } | ||
197 | } | 202 | } |
198 | } | 203 | } |
199 | 204 | ||
diff --git a/linden/indra/newview/llfolderview.cpp b/linden/indra/newview/llfolderview.cpp index 8cefd5b..58d0c42 100644 --- a/linden/indra/newview/llfolderview.cpp +++ b/linden/indra/newview/llfolderview.cpp | |||
@@ -4522,7 +4522,7 @@ BOOL LLInventoryFilter::check(LLFolderViewItem* item) | |||
4522 | } | 4522 | } |
4523 | LLFolderViewEventListener* listener = item->getListener(); | 4523 | LLFolderViewEventListener* listener = item->getListener(); |
4524 | mSubStringMatchOffset = mFilterSubString.size() ? item->getSearchableLabel().find(mFilterSubString) : std::string::npos; | 4524 | mSubStringMatchOffset = mFilterSubString.size() ? item->getSearchableLabel().find(mFilterSubString) : std::string::npos; |
4525 | BOOL passed = (0x1 << listener->getInventoryType() & mFilterOps.mFilterTypes || listener->getInventoryType() == LLInventoryType::IT_NONE) | 4525 | BOOL passed = (listener->getNInventoryType() & mFilterOps.mFilterTypes || listener->getNInventoryType() == LLInventoryType::NIT_NONE) |
4526 | && (mFilterSubString.size() == 0 || mSubStringMatchOffset != std::string::npos) | 4526 | && (mFilterSubString.size() == 0 || mSubStringMatchOffset != std::string::npos) |
4527 | && ((listener->getPermissionMask() & mFilterOps.mPermissions) == mFilterOps.mPermissions) | 4527 | && ((listener->getPermissionMask() & mFilterOps.mPermissions) == mFilterOps.mPermissions) |
4528 | && (listener->getCreationDate() >= earliest && listener->getCreationDate() <= mFilterOps.mMaxDate); | 4528 | && (listener->getCreationDate() >= earliest && listener->getCreationDate() <= mFilterOps.mMaxDate); |
@@ -4800,9 +4800,9 @@ void LLInventoryFilter::setModified(EFilterBehavior behavior) | |||
4800 | } | 4800 | } |
4801 | } | 4801 | } |
4802 | 4802 | ||
4803 | BOOL LLInventoryFilter::isFilterWith(LLInventoryType::EType t) | 4803 | BOOL LLInventoryFilter::isFilterWith(LLInventoryType::NType t) |
4804 | { | 4804 | { |
4805 | return mFilterOps.mFilterTypes & (0x01 << t); | 4805 | return mFilterOps.mFilterTypes & t; |
4806 | } | 4806 | } |
4807 | 4807 | ||
4808 | std::string LLInventoryFilter::getFilterText() | 4808 | std::string LLInventoryFilter::getFilterText() |
@@ -4812,6 +4812,11 @@ std::string LLInventoryFilter::getFilterText() | |||
4812 | return mFilterText; | 4812 | return mFilterText; |
4813 | } | 4813 | } |
4814 | 4814 | ||
4815 | return rebuildFilterText(); | ||
4816 | } | ||
4817 | |||
4818 | std::string LLInventoryFilter::rebuildFilterText() | ||
4819 | { | ||
4815 | mNeedTextRebuild = FALSE; | 4820 | mNeedTextRebuild = FALSE; |
4816 | std::string filtered_types; | 4821 | std::string filtered_types; |
4817 | std::string not_filtered_types; | 4822 | std::string not_filtered_types; |
@@ -4820,7 +4825,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4820 | S32 num_filter_types = 0; | 4825 | S32 num_filter_types = 0; |
4821 | mFilterText.clear(); | 4826 | mFilterText.clear(); |
4822 | 4827 | ||
4823 | if (isFilterWith(LLInventoryType::IT_ANIMATION)) | 4828 | if (isFilterWith(LLInventoryType::NIT_ANIMATION)) |
4824 | { | 4829 | { |
4825 | filtered_types += " Animations,"; | 4830 | filtered_types += " Animations,"; |
4826 | filtered_by_type = TRUE; | 4831 | filtered_by_type = TRUE; |
@@ -4832,7 +4837,19 @@ std::string LLInventoryFilter::getFilterText() | |||
4832 | filtered_by_all_types = FALSE; | 4837 | filtered_by_all_types = FALSE; |
4833 | } | 4838 | } |
4834 | 4839 | ||
4835 | if (isFilterWith(LLInventoryType::IT_CALLINGCARD)) | 4840 | if (isFilterWith(LLInventoryType::NIT_BODYPART)) |
4841 | { | ||
4842 | filtered_types += " Body Parts,"; | ||
4843 | filtered_by_type = TRUE; | ||
4844 | num_filter_types++; | ||
4845 | } | ||
4846 | else | ||
4847 | { | ||
4848 | not_filtered_types += " Body Parts,"; | ||
4849 | filtered_by_all_types = FALSE; | ||
4850 | } | ||
4851 | |||
4852 | if (isFilterWith(LLInventoryType::NIT_CALLCARD)) | ||
4836 | { | 4853 | { |
4837 | filtered_types += " Calling Cards,"; | 4854 | filtered_types += " Calling Cards,"; |
4838 | filtered_by_type = TRUE; | 4855 | filtered_by_type = TRUE; |
@@ -4844,7 +4861,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4844 | filtered_by_all_types = FALSE; | 4861 | filtered_by_all_types = FALSE; |
4845 | } | 4862 | } |
4846 | 4863 | ||
4847 | if (isFilterWith(LLInventoryType::IT_WEARABLE)) | 4864 | if (isFilterWith(LLInventoryType::NIT_CLOTHING)) |
4848 | { | 4865 | { |
4849 | filtered_types += " Clothing,"; | 4866 | filtered_types += " Clothing,"; |
4850 | filtered_by_type = TRUE; | 4867 | filtered_by_type = TRUE; |
@@ -4856,7 +4873,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4856 | filtered_by_all_types = FALSE; | 4873 | filtered_by_all_types = FALSE; |
4857 | } | 4874 | } |
4858 | 4875 | ||
4859 | if (isFilterWith(LLInventoryType::IT_GESTURE)) | 4876 | if (isFilterWith(LLInventoryType::NIT_GESTURE)) |
4860 | { | 4877 | { |
4861 | filtered_types += " Gestures,"; | 4878 | filtered_types += " Gestures,"; |
4862 | filtered_by_type = TRUE; | 4879 | filtered_by_type = TRUE; |
@@ -4868,7 +4885,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4868 | filtered_by_all_types = FALSE; | 4885 | filtered_by_all_types = FALSE; |
4869 | } | 4886 | } |
4870 | 4887 | ||
4871 | if (isFilterWith(LLInventoryType::IT_LANDMARK)) | 4888 | if (isFilterWith(LLInventoryType::NIT_LANDMARK)) |
4872 | { | 4889 | { |
4873 | filtered_types += " Landmarks,"; | 4890 | filtered_types += " Landmarks,"; |
4874 | filtered_by_type = TRUE; | 4891 | filtered_by_type = TRUE; |
@@ -4880,7 +4897,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4880 | filtered_by_all_types = FALSE; | 4897 | filtered_by_all_types = FALSE; |
4881 | } | 4898 | } |
4882 | 4899 | ||
4883 | if (isFilterWith(LLInventoryType::IT_NOTECARD)) | 4900 | if (isFilterWith(LLInventoryType::NIT_NOTECARD)) |
4884 | { | 4901 | { |
4885 | filtered_types += " Notecards,"; | 4902 | filtered_types += " Notecards,"; |
4886 | filtered_by_type = TRUE; | 4903 | filtered_by_type = TRUE; |
@@ -4892,7 +4909,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4892 | filtered_by_all_types = FALSE; | 4909 | filtered_by_all_types = FALSE; |
4893 | } | 4910 | } |
4894 | 4911 | ||
4895 | if (isFilterWith(LLInventoryType::IT_OBJECT) && isFilterWith(LLInventoryType::IT_ATTACHMENT)) | 4912 | if (isFilterWith(LLInventoryType::NIT_OBJECT)) |
4896 | { | 4913 | { |
4897 | filtered_types += " Objects,"; | 4914 | filtered_types += " Objects,"; |
4898 | filtered_by_type = TRUE; | 4915 | filtered_by_type = TRUE; |
@@ -4904,7 +4921,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4904 | filtered_by_all_types = FALSE; | 4921 | filtered_by_all_types = FALSE; |
4905 | } | 4922 | } |
4906 | 4923 | ||
4907 | if (isFilterWith(LLInventoryType::IT_LSL)) | 4924 | if (isFilterWith(LLInventoryType::NIT_SCRIPT_LSL2)) |
4908 | { | 4925 | { |
4909 | filtered_types += " Scripts,"; | 4926 | filtered_types += " Scripts,"; |
4910 | filtered_by_type = TRUE; | 4927 | filtered_by_type = TRUE; |
@@ -4916,7 +4933,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4916 | filtered_by_all_types = FALSE; | 4933 | filtered_by_all_types = FALSE; |
4917 | } | 4934 | } |
4918 | 4935 | ||
4919 | if (isFilterWith(LLInventoryType::IT_SOUND)) | 4936 | if (isFilterWith(LLInventoryType::NIT_SOUND)) |
4920 | { | 4937 | { |
4921 | filtered_types += " Sounds,"; | 4938 | filtered_types += " Sounds,"; |
4922 | filtered_by_type = TRUE; | 4939 | filtered_by_type = TRUE; |
@@ -4928,7 +4945,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4928 | filtered_by_all_types = FALSE; | 4945 | filtered_by_all_types = FALSE; |
4929 | } | 4946 | } |
4930 | 4947 | ||
4931 | if (isFilterWith(LLInventoryType::IT_TEXTURE)) | 4948 | if (isFilterWith(LLInventoryType::NIT_TEXTURE)) |
4932 | { | 4949 | { |
4933 | filtered_types += " Textures,"; | 4950 | filtered_types += " Textures,"; |
4934 | filtered_by_type = TRUE; | 4951 | filtered_by_type = TRUE; |
@@ -4940,7 +4957,7 @@ std::string LLInventoryFilter::getFilterText() | |||
4940 | filtered_by_all_types = FALSE; | 4957 | filtered_by_all_types = FALSE; |
4941 | } | 4958 | } |
4942 | 4959 | ||
4943 | if (isFilterWith(LLInventoryType::IT_SNAPSHOT)) | 4960 | if (isFilterWith(LLInventoryType::NIT_SNAPSHOT)) |
4944 | { | 4961 | { |
4945 | filtered_types += " Snapshots,"; | 4962 | filtered_types += " Snapshots,"; |
4946 | filtered_by_type = TRUE; | 4963 | filtered_by_type = TRUE; |
diff --git a/linden/indra/newview/llfolderview.h b/linden/indra/newview/llfolderview.h index 7978386..af3248d 100644 --- a/linden/indra/newview/llfolderview.h +++ b/linden/indra/newview/llfolderview.h | |||
@@ -103,6 +103,7 @@ public: | |||
103 | virtual BOOL isUpToDate() const = 0; | 103 | virtual BOOL isUpToDate() const = 0; |
104 | virtual BOOL hasChildren() const = 0; | 104 | virtual BOOL hasChildren() const = 0; |
105 | virtual LLInventoryType::EType getInventoryType() const = 0; | 105 | virtual LLInventoryType::EType getInventoryType() const = 0; |
106 | virtual LLInventoryType::NType getNInventoryType() const = 0; | ||
106 | virtual void performAction(LLFolderView* folder, LLInventoryModel* model, std::string action) {} | 107 | virtual void performAction(LLFolderView* folder, LLInventoryModel* model, std::string action) {} |
107 | 108 | ||
108 | // This method should be called when a drag begins. returns TRUE | 109 | // This method should be called when a drag begins. returns TRUE |
@@ -221,6 +222,7 @@ public: | |||
221 | void clearModified() { mModified = FALSE; mFilterBehavior = FILTER_NONE; } | 222 | void clearModified() { mModified = FALSE; mFilterBehavior = FILTER_NONE; } |
222 | const std::string getName() const { return mName; } | 223 | const std::string getName() const { return mName; } |
223 | std::string getFilterText(); | 224 | std::string getFilterText(); |
225 | std::string rebuildFilterText(); | ||
224 | 226 | ||
225 | void setFilterCount(S32 count) { mFilterCount = count; } | 227 | void setFilterCount(S32 count) { mFilterCount = count; } |
226 | S32 getFilterCount() { return mFilterCount; } | 228 | S32 getFilterCount() { return mFilterCount; } |
@@ -229,7 +231,7 @@ public: | |||
229 | void markDefault(); | 231 | void markDefault(); |
230 | void resetDefault(); | 232 | void resetDefault(); |
231 | 233 | ||
232 | BOOL isFilterWith(LLInventoryType::EType t); | 234 | BOOL isFilterWith(LLInventoryType::NType t); |
233 | 235 | ||
234 | S32 getCurrentGeneration() const { return mFilterGeneration; } | 236 | S32 getCurrentGeneration() const { return mFilterGeneration; } |
235 | S32 getMinRequiredGeneration() const { return mMinRequiredGeneration; } | 237 | S32 getMinRequiredGeneration() const { return mMinRequiredGeneration; } |
diff --git a/linden/indra/newview/llinventorybridge.cpp b/linden/indra/newview/llinventorybridge.cpp index 12670e2..bde36cc 100644 --- a/linden/indra/newview/llinventorybridge.cpp +++ b/linden/indra/newview/llinventorybridge.cpp | |||
@@ -722,6 +722,7 @@ LLInvFVBridge* LLInvFVBridge::createBridge(LLAssetType::EType asset_type, | |||
722 | if (new_listener) | 722 | if (new_listener) |
723 | { | 723 | { |
724 | new_listener->mInvType = inv_type; | 724 | new_listener->mInvType = inv_type; |
725 | new_listener->mNInvType = calc_ntype(inv_type, asset_type, flags); | ||
725 | } | 726 | } |
726 | 727 | ||
727 | return new_listener; | 728 | return new_listener; |
diff --git a/linden/indra/newview/llinventorybridge.h b/linden/indra/newview/llinventorybridge.h index fc04b28..329e57f 100644 --- a/linden/indra/newview/llinventorybridge.h +++ b/linden/indra/newview/llinventorybridge.h | |||
@@ -192,7 +192,15 @@ public: | |||
192 | virtual BOOL dragOrDrop(MASK mask, BOOL drop, | 192 | virtual BOOL dragOrDrop(MASK mask, BOOL drop, |
193 | EDragAndDropType cargo_type, | 193 | EDragAndDropType cargo_type, |
194 | void* cargo_data) { return FALSE; } | 194 | void* cargo_data) { return FALSE; } |
195 | virtual LLInventoryType::EType getInventoryType() const { return mInvType; } | 195 | |
196 | virtual LLInventoryType::EType getInventoryType() const | ||
197 | { | ||
198 | return mInvType; | ||
199 | } | ||
200 | virtual LLInventoryType::NType getNInventoryType() const | ||
201 | { | ||
202 | return mNInvType; | ||
203 | } | ||
196 | 204 | ||
197 | // LLInvFVBridge functionality | 205 | // LLInvFVBridge functionality |
198 | virtual void clearDisplayName() {} | 206 | virtual void clearDisplayName() {} |
@@ -221,6 +229,7 @@ protected: | |||
221 | LLInventoryPanel* mInventoryPanel; | 229 | LLInventoryPanel* mInventoryPanel; |
222 | LLUUID mUUID; // item id | 230 | LLUUID mUUID; // item id |
223 | LLInventoryType::EType mInvType; | 231 | LLInventoryType::EType mInvType; |
232 | LLInventoryType::NType mNInvType; | ||
224 | }; | 233 | }; |
225 | 234 | ||
226 | 235 | ||
diff --git a/linden/indra/newview/llinventoryview.cpp b/linden/indra/newview/llinventoryview.cpp index f9dd70d..52c3b7e 100644 --- a/linden/indra/newview/llinventoryview.cpp +++ b/linden/indra/newview/llinventoryview.cpp | |||
@@ -44,6 +44,7 @@ | |||
44 | #include "llradiogroup.h" | 44 | #include "llradiogroup.h" |
45 | #include "llspinctrl.h" | 45 | #include "llspinctrl.h" |
46 | #include "lltextbox.h" | 46 | #include "lltextbox.h" |
47 | #include "llcombobox.h" | ||
47 | #include "llui.h" | 48 | #include "llui.h" |
48 | 49 | ||
49 | #include "llfirstuse.h" | 50 | #include "llfirstuse.h" |
@@ -181,18 +182,19 @@ void LLInventoryViewFinder::updateElementsFromFilter() | |||
181 | 182 | ||
182 | // update the ui elements | 183 | // update the ui elements |
183 | LLFloater::setTitle(mFilter->getName()); | 184 | LLFloater::setTitle(mFilter->getName()); |
184 | childSetValue("check_animation", (S32) (filter_types & 0x1 << LLInventoryType::IT_ANIMATION)); | 185 | |
185 | 186 | childSetValue("check_animation", (S32) (filter_types & LLInventoryType::NIT_ANIMATION)); | |
186 | childSetValue("check_calling_card", (S32) (filter_types & 0x1 << LLInventoryType::IT_CALLINGCARD)); | 187 | childSetValue("check_bodypart", (S32) (filter_types & LLInventoryType::NIT_BODYPART)); |
187 | childSetValue("check_clothing", (S32) (filter_types & 0x1 << LLInventoryType::IT_WEARABLE)); | 188 | childSetValue("check_calling_card", (S32) (filter_types & LLInventoryType::NIT_CALLCARD)); |
188 | childSetValue("check_gesture", (S32) (filter_types & 0x1 << LLInventoryType::IT_GESTURE)); | 189 | childSetValue("check_clothing", (S32) (filter_types & LLInventoryType::NIT_CLOTHING)); |
189 | childSetValue("check_landmark", (S32) (filter_types & 0x1 << LLInventoryType::IT_LANDMARK)); | 190 | childSetValue("check_gesture", (S32) (filter_types & LLInventoryType::NIT_GESTURE)); |
190 | childSetValue("check_notecard", (S32) (filter_types & 0x1 << LLInventoryType::IT_NOTECARD)); | 191 | childSetValue("check_landmark", (S32) (filter_types & LLInventoryType::NIT_LANDMARK)); |
191 | childSetValue("check_object", (S32) (filter_types & 0x1 << LLInventoryType::IT_OBJECT)); | 192 | childSetValue("check_notecard", (S32) (filter_types & LLInventoryType::NIT_NOTECARD)); |
192 | childSetValue("check_script", (S32) (filter_types & 0x1 << LLInventoryType::IT_LSL)); | 193 | childSetValue("check_object", (S32) (filter_types & LLInventoryType::NIT_OBJECT)); |
193 | childSetValue("check_sound", (S32) (filter_types & 0x1 << LLInventoryType::IT_SOUND)); | 194 | childSetValue("check_script", (S32) (filter_types & LLInventoryType::NIT_SCRIPT_LSL2)); |
194 | childSetValue("check_texture", (S32) (filter_types & 0x1 << LLInventoryType::IT_TEXTURE)); | 195 | childSetValue("check_sound", (S32) (filter_types & LLInventoryType::NIT_SOUND)); |
195 | childSetValue("check_snapshot", (S32) (filter_types & 0x1 << LLInventoryType::IT_SNAPSHOT)); | 196 | childSetValue("check_texture", (S32) (filter_types & LLInventoryType::NIT_TEXTURE)); |
197 | childSetValue("check_snapshot", (S32) (filter_types & LLInventoryType::NIT_SNAPSHOT)); | ||
196 | childSetValue("check_show_empty", show_folders == LLInventoryFilter::SHOW_ALL_FOLDERS); | 198 | childSetValue("check_show_empty", show_folders == LLInventoryFilter::SHOW_ALL_FOLDERS); |
197 | childSetValue("check_since_logoff", mFilter->isSinceLogoff()); | 199 | childSetValue("check_since_logoff", mFilter->isSinceLogoff()); |
198 | mSpinSinceHours->set((F32)(hours % 24)); | 200 | mSpinSinceHours->set((F32)(hours % 24)); |
@@ -206,26 +208,31 @@ void LLInventoryViewFinder::draw() | |||
206 | 208 | ||
207 | if (!childGetValue("check_animation")) | 209 | if (!childGetValue("check_animation")) |
208 | { | 210 | { |
209 | filter &= ~(0x1 << LLInventoryType::IT_ANIMATION); | 211 | filter &= ~(LLInventoryType::NIT_ANIMATION); |
210 | filtered_by_all_types = FALSE; | 212 | filtered_by_all_types = FALSE; |
211 | } | 213 | } |
212 | 214 | ||
215 | if (!childGetValue("check_bodypart")) | ||
216 | { | ||
217 | filter &= ~(LLInventoryType::NIT_BODYPART); | ||
218 | filtered_by_all_types = FALSE; | ||
219 | } | ||
213 | 220 | ||
214 | if (!childGetValue("check_calling_card")) | 221 | if (!childGetValue("check_calling_card")) |
215 | { | 222 | { |
216 | filter &= ~(0x1 << LLInventoryType::IT_CALLINGCARD); | 223 | filter &= ~(LLInventoryType::NIT_CALLCARD); |
217 | filtered_by_all_types = FALSE; | 224 | filtered_by_all_types = FALSE; |
218 | } | 225 | } |
219 | 226 | ||
220 | if (!childGetValue("check_clothing")) | 227 | if (!childGetValue("check_clothing")) |
221 | { | 228 | { |
222 | filter &= ~(0x1 << LLInventoryType::IT_WEARABLE); | 229 | filter &= ~(LLInventoryType::NIT_CLOTHING); |
223 | filtered_by_all_types = FALSE; | 230 | filtered_by_all_types = FALSE; |
224 | } | 231 | } |
225 | 232 | ||
226 | if (!childGetValue("check_gesture")) | 233 | if (!childGetValue("check_gesture")) |
227 | { | 234 | { |
228 | filter &= ~(0x1 << LLInventoryType::IT_GESTURE); | 235 | filter &= ~(LLInventoryType::NIT_GESTURE); |
229 | filtered_by_all_types = FALSE; | 236 | filtered_by_all_types = FALSE; |
230 | } | 237 | } |
231 | 238 | ||
@@ -233,52 +240,53 @@ void LLInventoryViewFinder::draw() | |||
233 | 240 | ||
234 | 241 | ||
235 | { | 242 | { |
236 | filter &= ~(0x1 << LLInventoryType::IT_LANDMARK); | 243 | filter &= ~(LLInventoryType::NIT_LANDMARK); |
237 | filtered_by_all_types = FALSE; | 244 | filtered_by_all_types = FALSE; |
238 | } | 245 | } |
239 | 246 | ||
240 | if (!childGetValue("check_notecard")) | 247 | if (!childGetValue("check_notecard")) |
241 | { | 248 | { |
242 | filter &= ~(0x1 << LLInventoryType::IT_NOTECARD); | 249 | filter &= ~(LLInventoryType::NIT_NOTECARD); |
243 | filtered_by_all_types = FALSE; | 250 | filtered_by_all_types = FALSE; |
244 | } | 251 | } |
245 | 252 | ||
246 | if (!childGetValue("check_object")) | 253 | if (!childGetValue("check_object")) |
247 | { | 254 | { |
248 | filter &= ~(0x1 << LLInventoryType::IT_OBJECT); | 255 | filter &= ~(LLInventoryType::NIT_OBJECT); |
249 | filter &= ~(0x1 << LLInventoryType::IT_ATTACHMENT); | ||
250 | filtered_by_all_types = FALSE; | 256 | filtered_by_all_types = FALSE; |
251 | } | 257 | } |
252 | 258 | ||
253 | if (!childGetValue("check_script")) | 259 | if (!childGetValue("check_script")) |
254 | { | 260 | { |
255 | filter &= ~(0x1 << LLInventoryType::IT_LSL); | 261 | filter &= ~(LLInventoryType::NIT_SCRIPT_LSL2); |
256 | filtered_by_all_types = FALSE; | 262 | filtered_by_all_types = FALSE; |
257 | } | 263 | } |
258 | 264 | ||
259 | if (!childGetValue("check_sound")) | 265 | if (!childGetValue("check_sound")) |
260 | { | 266 | { |
261 | filter &= ~(0x1 << LLInventoryType::IT_SOUND); | 267 | filter &= ~(LLInventoryType::NIT_SOUND); |
262 | filtered_by_all_types = FALSE; | 268 | filtered_by_all_types = FALSE; |
263 | } | 269 | } |
264 | 270 | ||
265 | if (!childGetValue("check_texture")) | 271 | if (!childGetValue("check_texture")) |
266 | { | 272 | { |
267 | filter &= ~(0x1 << LLInventoryType::IT_TEXTURE); | 273 | filter &= ~(LLInventoryType::NIT_TEXTURE); |
268 | filtered_by_all_types = FALSE; | 274 | filtered_by_all_types = FALSE; |
269 | } | 275 | } |
270 | 276 | ||
271 | if (!childGetValue("check_snapshot")) | 277 | if (!childGetValue("check_snapshot")) |
272 | { | 278 | { |
273 | filter &= ~(0x1 << LLInventoryType::IT_SNAPSHOT); | 279 | filter &= ~(LLInventoryType::NIT_SNAPSHOT); |
274 | filtered_by_all_types = FALSE; | 280 | filtered_by_all_types = FALSE; |
275 | } | 281 | } |
276 | 282 | ||
283 | /* | ||
277 | if (!filtered_by_all_types) | 284 | if (!filtered_by_all_types) |
278 | { | 285 | { |
279 | // don't include folders in filter, unless I've selected everything | 286 | // don't include folders in filter, unless I've selected everything |
280 | filter &= ~(0x1 << LLInventoryType::IT_CATEGORY); | 287 | filter &= ~(LLInventoryType::NIT_CATEGORY); |
281 | } | 288 | } |
289 | */ | ||
282 | 290 | ||
283 | // update the panel, panel will update the filter | 291 | // update the panel, panel will update the filter |
284 | mInventoryView->mActivePanel->setShowFolderState(getCheckShowEmpty() ? | 292 | mInventoryView->mActivePanel->setShowFolderState(getCheckShowEmpty() ? |
@@ -344,6 +352,7 @@ void LLInventoryViewFinder::selectAllTypes(void* user_data) | |||
344 | if(!self) return; | 352 | if(!self) return; |
345 | 353 | ||
346 | self->childSetValue("check_animation", TRUE); | 354 | self->childSetValue("check_animation", TRUE); |
355 | self->childSetValue("check_bodypart", TRUE); | ||
347 | self->childSetValue("check_calling_card", TRUE); | 356 | self->childSetValue("check_calling_card", TRUE); |
348 | self->childSetValue("check_clothing", TRUE); | 357 | self->childSetValue("check_clothing", TRUE); |
349 | self->childSetValue("check_gesture", TRUE); | 358 | self->childSetValue("check_gesture", TRUE); |
@@ -389,6 +398,7 @@ void LLInventoryViewFinder::selectNoTypes(void* user_data) | |||
389 | 398 | ||
390 | 399 | ||
391 | self->childSetValue("check_animation", FALSE); | 400 | self->childSetValue("check_animation", FALSE); |
401 | self->childSetValue("check_bodypart", FALSE); | ||
392 | self->childSetValue("check_calling_card", FALSE); | 402 | self->childSetValue("check_calling_card", FALSE); |
393 | self->childSetValue("check_clothing", FALSE); | 403 | self->childSetValue("check_clothing", FALSE); |
394 | self->childSetValue("check_gesture", FALSE); | 404 | self->childSetValue("check_gesture", FALSE); |
@@ -549,6 +559,12 @@ void LLInventoryView::init(LLInventoryModel* inventory) | |||
549 | mSearchEditor->setSearchCallback(onSearchEdit, this); | 559 | mSearchEditor->setSearchCallback(onSearchEdit, this); |
550 | } | 560 | } |
551 | 561 | ||
562 | mQuickFilterCombo = getChild<LLComboBox>("Quick Filter"); | ||
563 | if (mQuickFilterCombo) | ||
564 | { | ||
565 | mQuickFilterCombo->setCommitCallback(onQuickFilterCommit); | ||
566 | } | ||
567 | |||
552 | sActiveViews.put(this); | 568 | sActiveViews.put(this); |
553 | 569 | ||
554 | gInventory.addObserver(this); | 570 | gInventory.addObserver(this); |
@@ -617,6 +633,11 @@ void LLInventoryView::draw() | |||
617 | { | 633 | { |
618 | mSearchEditor->setText(mActivePanel->getFilterSubString()); | 634 | mSearchEditor->setText(mActivePanel->getFilterSubString()); |
619 | } | 635 | } |
636 | if (mActivePanel && mQuickFilterCombo) | ||
637 | { | ||
638 | refreshQuickFilter( mQuickFilterCombo ); | ||
639 | } | ||
640 | |||
620 | LLFloater::draw(); | 641 | LLFloater::draw(); |
621 | } | 642 | } |
622 | 643 | ||
@@ -922,16 +943,9 @@ void LLInventoryView::onClearSearch(void* user_data) | |||
922 | LLInventoryView* self = (LLInventoryView*)user_data; | 943 | LLInventoryView* self = (LLInventoryView*)user_data; |
923 | if(!self) return; | 944 | if(!self) return; |
924 | 945 | ||
925 | LLFloater *finder = self->getFinder(); | ||
926 | if (self->mActivePanel) | 946 | if (self->mActivePanel) |
927 | { | 947 | { |
928 | self->mActivePanel->setFilterSubString(LLStringUtil::null); | 948 | self->mActivePanel->setFilterSubString(LLStringUtil::null); |
929 | self->mActivePanel->setFilterTypes(0xffffffff); | ||
930 | } | ||
931 | |||
932 | if (finder) | ||
933 | { | ||
934 | LLInventoryViewFinder::selectAllTypes(finder); | ||
935 | } | 949 | } |
936 | 950 | ||
937 | // re-open folders that were initially open | 951 | // re-open folders that were initially open |
@@ -981,6 +995,241 @@ void LLInventoryView::onSearchEdit(const std::string& search_string, void* user_ | |||
981 | } | 995 | } |
982 | 996 | ||
983 | 997 | ||
998 | //static | ||
999 | void LLInventoryView::onQuickFilterCommit(LLUICtrl* ctrl, void* user_data) | ||
1000 | { | ||
1001 | |||
1002 | LLComboBox* quickfilter = (LLComboBox*)ctrl; | ||
1003 | |||
1004 | |||
1005 | LLInventoryView* view = (LLInventoryView*)(quickfilter->getParent()); | ||
1006 | if (!view->mActivePanel) | ||
1007 | { | ||
1008 | return; | ||
1009 | } | ||
1010 | |||
1011 | |||
1012 | std::string item_type = quickfilter->getSimple(); | ||
1013 | U32 filter_type; | ||
1014 | |||
1015 | if (view->getString("filter_type_animation") == item_type) | ||
1016 | { | ||
1017 | filter_type = LLInventoryType::NIT_ANIMATION; | ||
1018 | } | ||
1019 | |||
1020 | else if (view->getString("filter_type_bodypart") == item_type) | ||
1021 | { | ||
1022 | filter_type = LLInventoryType::NIT_BODYPART; | ||
1023 | } | ||
1024 | |||
1025 | else if (view->getString("filter_type_callingcard") == item_type) | ||
1026 | { | ||
1027 | filter_type = LLInventoryType::NIT_CALLCARD; | ||
1028 | } | ||
1029 | |||
1030 | else if (view->getString("filter_type_clothing") == item_type) | ||
1031 | { | ||
1032 | filter_type = LLInventoryType::NIT_CLOTHING; | ||
1033 | } | ||
1034 | |||
1035 | else if (view->getString("filter_type_gesture") == item_type) | ||
1036 | { | ||
1037 | filter_type = LLInventoryType::NIT_GESTURE; | ||
1038 | } | ||
1039 | |||
1040 | else if (view->getString("filter_type_landmark") == item_type) | ||
1041 | { | ||
1042 | filter_type = LLInventoryType::NIT_LANDMARK; | ||
1043 | } | ||
1044 | |||
1045 | else if (view->getString("filter_type_notecard") == item_type) | ||
1046 | { | ||
1047 | filter_type = LLInventoryType::NIT_NOTECARD; | ||
1048 | } | ||
1049 | |||
1050 | else if (view->getString("filter_type_object") == item_type) | ||
1051 | { | ||
1052 | filter_type = LLInventoryType::NIT_OBJECT; | ||
1053 | } | ||
1054 | |||
1055 | else if (view->getString("filter_type_script") == item_type) | ||
1056 | { | ||
1057 | filter_type = LLInventoryType::NIT_SCRIPT_LSL2; | ||
1058 | } | ||
1059 | |||
1060 | else if (view->getString("filter_type_sound") == item_type) | ||
1061 | { | ||
1062 | filter_type = LLInventoryType::NIT_SOUND; | ||
1063 | } | ||
1064 | |||
1065 | else if (view->getString("filter_type_texture") == item_type) | ||
1066 | { | ||
1067 | filter_type = LLInventoryType::NIT_TEXTURE; | ||
1068 | } | ||
1069 | |||
1070 | else if (view->getString("filter_type_snapshot") == item_type) | ||
1071 | { | ||
1072 | filter_type = LLInventoryType::NIT_SNAPSHOT; | ||
1073 | } | ||
1074 | |||
1075 | else if (view->getString("filter_type_custom") == item_type) | ||
1076 | { | ||
1077 | // When they select custom, show the floater then return | ||
1078 | if( !(view->filtersVisible(view)) ) | ||
1079 | { | ||
1080 | view->toggleFindOptions(); | ||
1081 | } | ||
1082 | return; | ||
1083 | } | ||
1084 | |||
1085 | else if (view->getString("filter_type_all") == item_type) | ||
1086 | { | ||
1087 | // Show all types | ||
1088 | filter_type = 0xffffffff; | ||
1089 | } | ||
1090 | |||
1091 | else | ||
1092 | { | ||
1093 | llwarns << "Ignoring unknown filter: " << item_type << llendl; | ||
1094 | return; | ||
1095 | } | ||
1096 | |||
1097 | view->mActivePanel->setFilterTypes( filter_type ); | ||
1098 | |||
1099 | // Start fetching inventory in the background, so we have | ||
1100 | // some items to show the user. | ||
1101 | gInventory.startBackgroundFetch(); | ||
1102 | |||
1103 | // Update the Inventory window text | ||
1104 | view->setFilterTextFromFilter(); | ||
1105 | |||
1106 | // Force the filters window to update itself, if it's open. | ||
1107 | LLInventoryViewFinder* finder = view->getFinder(); | ||
1108 | if( finder ) | ||
1109 | { | ||
1110 | finder->updateElementsFromFilter(); | ||
1111 | } | ||
1112 | |||
1113 | // llinfos << "Quick Filter: " << item_type << llendl; | ||
1114 | |||
1115 | } | ||
1116 | |||
1117 | |||
1118 | |||
1119 | //static | ||
1120 | void LLInventoryView::refreshQuickFilter(LLUICtrl* ctrl) | ||
1121 | { | ||
1122 | |||
1123 | LLInventoryView* view = (LLInventoryView*)(ctrl->getParent()); | ||
1124 | if (!view->mActivePanel) | ||
1125 | { | ||
1126 | return; | ||
1127 | } | ||
1128 | |||
1129 | LLComboBox* quickfilter = view->getChild<LLComboBox>("Quick Filter"); | ||
1130 | if (!quickfilter) | ||
1131 | { | ||
1132 | return; | ||
1133 | } | ||
1134 | |||
1135 | |||
1136 | U32 filter_type = view->mActivePanel->getFilterTypes(); | ||
1137 | filter_type &= LLInventoryType::NIT_ALL; | ||
1138 | |||
1139 | |||
1140 | //llinfos << "filter_type: " << filter_type << llendl; | ||
1141 | |||
1142 | std::string selection; | ||
1143 | |||
1144 | |||
1145 | if (filter_type == LLInventoryType::NIT_ALL) | ||
1146 | { | ||
1147 | selection = view->getString("filter_type_all"); | ||
1148 | } | ||
1149 | |||
1150 | else if (filter_type == LLInventoryType::NIT_NONE) | ||
1151 | { | ||
1152 | selection = view->getString("filter_type_custom"); | ||
1153 | } | ||
1154 | |||
1155 | else if (filter_type == (filter_type & LLInventoryType::NIT_ANIMATION)) | ||
1156 | { | ||
1157 | selection = view->getString("filter_type_animation"); | ||
1158 | } | ||
1159 | |||
1160 | else if (filter_type == (filter_type & LLInventoryType::NIT_BODYPART)) | ||
1161 | { | ||
1162 | selection = view->getString("filter_type_bodypart"); | ||
1163 | } | ||
1164 | |||
1165 | else if (filter_type == (filter_type & LLInventoryType::NIT_CALLCARD)) | ||
1166 | { | ||
1167 | selection = view->getString("filter_type_callingcard"); | ||
1168 | } | ||
1169 | |||
1170 | else if (filter_type == (filter_type & LLInventoryType::NIT_CLOTHING)) | ||
1171 | { | ||
1172 | selection = view->getString("filter_type_clothing"); | ||
1173 | } | ||
1174 | |||
1175 | else if (filter_type == (filter_type & LLInventoryType::NIT_GESTURE)) | ||
1176 | { | ||
1177 | selection = view->getString("filter_type_gesture"); | ||
1178 | } | ||
1179 | |||
1180 | else if (filter_type == (filter_type & LLInventoryType::NIT_LANDMARK)) | ||
1181 | { | ||
1182 | selection = view->getString("filter_type_landmark"); | ||
1183 | } | ||
1184 | |||
1185 | else if (filter_type == (filter_type & LLInventoryType::NIT_NOTECARD)) | ||
1186 | { | ||
1187 | selection = view->getString("filter_type_notecard"); | ||
1188 | } | ||
1189 | |||
1190 | else if (filter_type == (filter_type & LLInventoryType::NIT_OBJECT)) | ||
1191 | { | ||
1192 | selection = view->getString("filter_type_object"); | ||
1193 | } | ||
1194 | |||
1195 | else if (filter_type == (filter_type & LLInventoryType::NIT_SCRIPT_LSL2)) | ||
1196 | { | ||
1197 | selection = view->getString("filter_type_script"); | ||
1198 | } | ||
1199 | |||
1200 | else if (filter_type == (filter_type & LLInventoryType::NIT_SOUND)) | ||
1201 | { | ||
1202 | selection = view->getString("filter_type_sound"); | ||
1203 | } | ||
1204 | |||
1205 | else if (filter_type == (filter_type & LLInventoryType::NIT_TEXTURE)) | ||
1206 | { | ||
1207 | selection = view->getString("filter_type_texture"); | ||
1208 | } | ||
1209 | |||
1210 | else if (filter_type == (filter_type & LLInventoryType::NIT_SNAPSHOT)) | ||
1211 | { | ||
1212 | selection = view->getString("filter_type_snapshot"); | ||
1213 | } | ||
1214 | |||
1215 | else | ||
1216 | { | ||
1217 | selection = view->getString("filter_type_custom"); | ||
1218 | } | ||
1219 | |||
1220 | |||
1221 | // Select the chosen item by label text | ||
1222 | BOOL result = quickfilter->setSimple( (selection) ); | ||
1223 | |||
1224 | if( !result ) | ||
1225 | { | ||
1226 | llinfos << "The item didn't exist: " << selection << llendl; | ||
1227 | } | ||
1228 | |||
1229 | } | ||
1230 | |||
1231 | |||
1232 | |||
984 | // static | 1233 | // static |
985 | // BOOL LLInventoryView::incrementalFind(LLFolderViewItem* first_item, const char *find_text, BOOL backward) | 1234 | // BOOL LLInventoryView::incrementalFind(LLFolderViewItem* first_item, const char *find_text, BOOL backward) |
986 | // { | 1235 | // { |
@@ -1079,124 +1328,163 @@ BOOL LLInventoryView::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, | |||
1079 | 1328 | ||
1080 | return handled; | 1329 | return handled; |
1081 | } | 1330 | } |
1331 | |||
1082 | std::string get_item_icon_name(LLAssetType::EType asset_type, | 1332 | std::string get_item_icon_name(LLAssetType::EType asset_type, |
1083 | LLInventoryType::EType inventory_type, | 1333 | LLInventoryType::EType inv_type, |
1084 | U32 attachment_point, | 1334 | U32 flags, |
1085 | BOOL item_is_multi ) | 1335 | BOOL item_is_multi ) |
1336 | { | ||
1337 | return get_item_icon_name( calc_ntype(inv_type, asset_type, flags), | ||
1338 | item_is_multi ); | ||
1339 | } | ||
1340 | |||
1341 | std::string get_item_icon_name(LLInventoryType::NType inv_ntype, | ||
1342 | BOOL item_is_multi ) | ||
1086 | { | 1343 | { |
1087 | EInventoryIcon idx = OBJECT_ICON_NAME; | 1344 | EInventoryIcon idx = OBJECT_ICON_NAME; |
1088 | if ( item_is_multi ) | 1345 | |
1089 | { | 1346 | switch( inv_ntype ) |
1090 | idx = OBJECT_MULTI_ICON_NAME; | ||
1091 | } | ||
1092 | |||
1093 | switch(asset_type) | ||
1094 | { | 1347 | { |
1095 | case LLAssetType::AT_TEXTURE: | 1348 | // BODY PARTS |
1096 | if(LLInventoryType::IT_SNAPSHOT == inventory_type) | ||
1097 | { | ||
1098 | idx = SNAPSHOT_ICON_NAME; | ||
1099 | } | ||
1100 | else | ||
1101 | { | ||
1102 | idx = TEXTURE_ICON_NAME; | ||
1103 | } | ||
1104 | break; | ||
1105 | 1349 | ||
1106 | case LLAssetType::AT_SOUND: | 1350 | case LLInventoryType::NIT_SHAPE: |
1107 | idx = SOUND_ICON_NAME; | ||
1108 | break; | ||
1109 | case LLAssetType::AT_CALLINGCARD: | ||
1110 | if(attachment_point!= 0) | ||
1111 | { | ||
1112 | idx = CALLINGCARD_ONLINE_ICON_NAME; | ||
1113 | } | ||
1114 | else | ||
1115 | { | ||
1116 | idx = CALLINGCARD_OFFLINE_ICON_NAME; | ||
1117 | } | ||
1118 | break; | ||
1119 | case LLAssetType::AT_LANDMARK: | ||
1120 | if(attachment_point!= 0) | ||
1121 | { | ||
1122 | idx = LANDMARK_VISITED_ICON_NAME; | ||
1123 | } | ||
1124 | else | ||
1125 | { | ||
1126 | idx = LANDMARK_ICON_NAME; | ||
1127 | } | ||
1128 | break; | ||
1129 | case LLAssetType::AT_SCRIPT: | ||
1130 | case LLAssetType::AT_LSL_TEXT: | ||
1131 | case LLAssetType::AT_LSL_BYTECODE: | ||
1132 | idx = SCRIPT_ICON_NAME; | ||
1133 | break; | ||
1134 | case LLAssetType::AT_CLOTHING: | ||
1135 | idx = CLOTHING_ICON_NAME; | ||
1136 | case LLAssetType::AT_BODYPART : | ||
1137 | if(LLAssetType::AT_BODYPART == asset_type) | ||
1138 | { | ||
1139 | idx = BODYPART_ICON_NAME; | ||
1140 | } | ||
1141 | switch(attachment_point) | ||
1142 | { | ||
1143 | case WT_SHAPE: | ||
1144 | idx = BODYPART_SHAPE_ICON_NAME; | 1351 | idx = BODYPART_SHAPE_ICON_NAME; |
1145 | break; | 1352 | break; |
1146 | case WT_SKIN: | 1353 | case LLInventoryType::NIT_SKIN: |
1147 | idx = BODYPART_SKIN_ICON_NAME; | 1354 | idx = BODYPART_SKIN_ICON_NAME; |
1148 | break; | 1355 | break; |
1149 | case WT_HAIR: | 1356 | case LLInventoryType::NIT_HAIR: |
1150 | idx = BODYPART_HAIR_ICON_NAME; | 1357 | idx = BODYPART_HAIR_ICON_NAME; |
1151 | break; | 1358 | break; |
1152 | case WT_EYES: | 1359 | case LLInventoryType::NIT_EYES: |
1153 | idx = BODYPART_EYES_ICON_NAME; | 1360 | idx = BODYPART_EYES_ICON_NAME; |
1154 | break; | 1361 | break; |
1155 | case WT_SHIRT: | 1362 | |
1363 | case LLInventoryType::NIT_BODYPART: | ||
1364 | idx = BODYPART_ICON_NAME; | ||
1365 | break; | ||
1366 | |||
1367 | |||
1368 | // CLOTHING | ||
1369 | |||
1370 | case LLInventoryType::NIT_SHIRT: | ||
1156 | idx = CLOTHING_SHIRT_ICON_NAME; | 1371 | idx = CLOTHING_SHIRT_ICON_NAME; |
1157 | break; | 1372 | break; |
1158 | case WT_PANTS: | 1373 | case LLInventoryType::NIT_PANTS: |
1159 | idx = CLOTHING_PANTS_ICON_NAME; | 1374 | idx = CLOTHING_PANTS_ICON_NAME; |
1160 | break; | 1375 | break; |
1161 | case WT_SHOES: | 1376 | case LLInventoryType::NIT_SHOES: |
1162 | idx = CLOTHING_SHOES_ICON_NAME; | 1377 | idx = CLOTHING_SHOES_ICON_NAME; |
1163 | break; | 1378 | break; |
1164 | case WT_SOCKS: | 1379 | case LLInventoryType::NIT_SOCKS: |
1165 | idx = CLOTHING_SOCKS_ICON_NAME; | 1380 | idx = CLOTHING_SOCKS_ICON_NAME; |
1166 | break; | 1381 | break; |
1167 | case WT_JACKET: | 1382 | case LLInventoryType::NIT_JACKET: |
1168 | idx = CLOTHING_JACKET_ICON_NAME; | 1383 | idx = CLOTHING_JACKET_ICON_NAME; |
1169 | break; | 1384 | break; |
1170 | case WT_GLOVES: | 1385 | case LLInventoryType::NIT_GLOVES: |
1171 | idx = CLOTHING_GLOVES_ICON_NAME; | 1386 | idx = CLOTHING_GLOVES_ICON_NAME; |
1172 | break; | 1387 | break; |
1173 | case WT_UNDERSHIRT: | 1388 | case LLInventoryType::NIT_UNDERSHIRT: |
1174 | idx = CLOTHING_UNDERSHIRT_ICON_NAME; | 1389 | idx = CLOTHING_UNDERSHIRT_ICON_NAME; |
1175 | break; | 1390 | break; |
1176 | case WT_UNDERPANTS: | 1391 | case LLInventoryType::NIT_UNDERPANTS: |
1177 | idx = CLOTHING_UNDERPANTS_ICON_NAME; | 1392 | idx = CLOTHING_UNDERPANTS_ICON_NAME; |
1178 | break; | 1393 | break; |
1179 | case WT_SKIRT: | 1394 | case LLInventoryType::NIT_SKIRT: |
1180 | idx = CLOTHING_SKIRT_ICON_NAME; | 1395 | idx = CLOTHING_SKIRT_ICON_NAME; |
1181 | break; | 1396 | break; |
1397 | |||
1398 | case LLInventoryType::NIT_CLOTHING: | ||
1399 | idx = CLOTHING_ICON_NAME; | ||
1400 | break; | ||
1401 | |||
1402 | |||
1403 | // TEXTURES / SNAPSHOTS | ||
1404 | |||
1405 | case LLInventoryType::NIT_SNAPSHOT: | ||
1406 | idx = SNAPSHOT_ICON_NAME; | ||
1407 | break; | ||
1408 | case LLInventoryType::NIT_TEXTURE: | ||
1409 | case LLInventoryType::NIT_IMAGE: | ||
1410 | idx = TEXTURE_ICON_NAME; | ||
1411 | break; | ||
1412 | |||
1413 | |||
1414 | // CALLING CARDS | ||
1415 | |||
1416 | case LLInventoryType::NIT_CALLCARD_ON: | ||
1417 | idx = CALLINGCARD_ONLINE_ICON_NAME; | ||
1418 | break; | ||
1419 | case LLInventoryType::NIT_CALLCARD_OFF: | ||
1420 | case LLInventoryType::NIT_CALLCARD: | ||
1421 | idx = CALLINGCARD_OFFLINE_ICON_NAME; | ||
1422 | break; | ||
1423 | |||
1424 | |||
1425 | // LANDMARKS | ||
1426 | |||
1427 | case LLInventoryType::NIT_LANDMARK_USED: | ||
1428 | idx = LANDMARK_VISITED_ICON_NAME; | ||
1429 | break; | ||
1430 | case LLInventoryType::NIT_LANDMARK_UNUSED: | ||
1431 | case LLInventoryType::NIT_LANDMARK: | ||
1432 | idx = LANDMARK_ICON_NAME; | ||
1433 | break; | ||
1434 | |||
1435 | |||
1436 | // SOUNDS | ||
1437 | |||
1438 | case LLInventoryType::NIT_SOUND: | ||
1439 | idx = SOUND_ICON_NAME; | ||
1440 | break; | ||
1441 | |||
1442 | |||
1443 | // ANIMATIONS | ||
1444 | |||
1445 | case LLInventoryType::NIT_ANIMATION: | ||
1446 | idx = ANIMATION_ICON_NAME; | ||
1447 | break; | ||
1448 | |||
1449 | |||
1450 | // GESTURES | ||
1451 | |||
1452 | case LLInventoryType::NIT_GESTURE: | ||
1453 | idx = GESTURE_ICON_NAME; | ||
1454 | break; | ||
1455 | |||
1456 | |||
1457 | // NOTECARD | ||
1458 | |||
1459 | case LLInventoryType::NIT_NOTECARD: | ||
1460 | idx = NOTECARD_ICON_NAME; | ||
1461 | break; | ||
1462 | |||
1463 | |||
1464 | // SCRIPTS | ||
1465 | |||
1466 | case LLInventoryType::NIT_SCRIPT_LSL2: | ||
1467 | idx = SCRIPT_ICON_NAME; | ||
1468 | break; | ||
1469 | |||
1470 | |||
1471 | // OBJECTS | ||
1472 | |||
1473 | case LLInventoryType::NIT_OBJECT: | ||
1474 | if( item_is_multi ) | ||
1475 | { | ||
1476 | idx = OBJECT_MULTI_ICON_NAME; | ||
1477 | } | ||
1478 | else | ||
1479 | { | ||
1480 | idx = OBJECT_ICON_NAME; | ||
1481 | } | ||
1482 | break; | ||
1483 | |||
1182 | default: | 1484 | default: |
1183 | // no-op, go with choice above | ||
1184 | break; | 1485 | break; |
1185 | } | ||
1186 | break; | ||
1187 | case LLAssetType::AT_NOTECARD: | ||
1188 | idx = NOTECARD_ICON_NAME; | ||
1189 | break; | ||
1190 | case LLAssetType::AT_ANIMATION: | ||
1191 | idx = ANIMATION_ICON_NAME; | ||
1192 | break; | ||
1193 | case LLAssetType::AT_GESTURE: | ||
1194 | idx = GESTURE_ICON_NAME; | ||
1195 | break; | ||
1196 | default: | ||
1197 | break; | ||
1198 | } | 1486 | } |
1199 | 1487 | ||
1200 | return ICON_NAME[idx]; | 1488 | return ICON_NAME[idx]; |
1201 | } | 1489 | } |
1202 | 1490 | ||
diff --git a/linden/indra/newview/llinventoryview.h b/linden/indra/newview/llinventoryview.h index a37d370..80e5768 100644 --- a/linden/indra/newview/llinventoryview.h +++ b/linden/indra/newview/llinventoryview.h | |||
@@ -58,6 +58,7 @@ class LLCheckBoxCtrl; | |||
58 | class LLSpinCtrl; | 58 | class LLSpinCtrl; |
59 | class LLScrollableContainerView; | 59 | class LLScrollableContainerView; |
60 | class LLTextBox; | 60 | class LLTextBox; |
61 | class LLComboBox; | ||
61 | class LLIconCtrl; | 62 | class LLIconCtrl; |
62 | class LLSaveFolderState; | 63 | class LLSaveFolderState; |
63 | class LLSearchEditor; | 64 | class LLSearchEditor; |
@@ -239,6 +240,8 @@ public: | |||
239 | static void onFoldersByName(void *user_data); | 240 | static void onFoldersByName(void *user_data); |
240 | static BOOL checkFoldersByName(void *user_data); | 241 | static BOOL checkFoldersByName(void *user_data); |
241 | static void onSearchEdit(const std::string& search_string, void* user_data ); | 242 | static void onSearchEdit(const std::string& search_string, void* user_data ); |
243 | static void onQuickFilterCommit(LLUICtrl* ctrl, void* user_data); | ||
244 | static void refreshQuickFilter(LLUICtrl* ctrl); | ||
242 | static void onFilterSelected(void* userdata, bool from_click); | 245 | static void onFilterSelected(void* userdata, bool from_click); |
243 | static void onSelectionChange(const std::deque<LLFolderViewItem*> &items, BOOL user_action, void* data); | 246 | static void onSelectionChange(const std::deque<LLFolderViewItem*> &items, BOOL user_action, void* data); |
244 | 247 | ||
@@ -259,6 +262,7 @@ protected: | |||
259 | 262 | ||
260 | protected: | 263 | protected: |
261 | LLSearchEditor* mSearchEditor; | 264 | LLSearchEditor* mSearchEditor; |
265 | LLComboBox* mQuickFilterCombo; | ||
262 | LLTabContainer* mFilterTabs; | 266 | LLTabContainer* mFilterTabs; |
263 | LLHandle<LLFloater> mFinderHandle; | 267 | LLHandle<LLFloater> mFinderHandle; |
264 | LLInventoryPanel* mActivePanel; | 268 | LLInventoryPanel* mActivePanel; |
@@ -344,6 +348,9 @@ std::string get_item_icon_name(LLAssetType::EType asset_type, | |||
344 | U32 attachment_point, | 348 | U32 attachment_point, |
345 | BOOL item_is_multi ); | 349 | BOOL item_is_multi ); |
346 | 350 | ||
351 | std::string get_item_icon_name(LLInventoryType::NType inv_ntype, | ||
352 | BOOL item_is_multi ); | ||
353 | |||
347 | LLUIImagePtr get_item_icon(LLAssetType::EType asset_type, | 354 | LLUIImagePtr get_item_icon(LLAssetType::EType asset_type, |
348 | LLInventoryType::EType inventory_type, | 355 | LLInventoryType::EType inventory_type, |
349 | U32 attachment_point, | 356 | U32 attachment_point, |
diff --git a/linden/indra/newview/llpanelinventory.cpp b/linden/indra/newview/llpanelinventory.cpp index 3c0e6d7..e41ecdc 100644 --- a/linden/indra/newview/llpanelinventory.cpp +++ b/linden/indra/newview/llpanelinventory.cpp | |||
@@ -146,6 +146,7 @@ public: | |||
146 | virtual BOOL isUpToDate() const { return TRUE; } | 146 | virtual BOOL isUpToDate() const { return TRUE; } |
147 | virtual BOOL hasChildren() const { return FALSE; } | 147 | virtual BOOL hasChildren() const { return FALSE; } |
148 | virtual LLInventoryType::EType getInventoryType() const { return LLInventoryType::IT_NONE; } | 148 | virtual LLInventoryType::EType getInventoryType() const { return LLInventoryType::IT_NONE; } |
149 | virtual LLInventoryType::NType getNInventoryType() const { return LLInventoryType::NIT_NONE; } | ||
149 | // LLDragAndDropBridge functionality | 150 | // LLDragAndDropBridge functionality |
150 | virtual BOOL startDrag(EDragAndDropType* type, LLUUID* id) const; | 151 | virtual BOOL startDrag(EDragAndDropType* type, LLUUID* id) const; |
151 | virtual BOOL dragOrDrop(MASK mask, BOOL drop, | 152 | virtual BOOL dragOrDrop(MASK mask, BOOL drop, |
diff --git a/linden/indra/newview/llwearable.h b/linden/indra/newview/llwearable.h index c5f9d06..00a53d3 100644 --- a/linden/indra/newview/llwearable.h +++ b/linden/indra/newview/llwearable.h | |||
@@ -37,28 +37,10 @@ | |||
37 | #include "llpermissions.h" | 37 | #include "llpermissions.h" |
38 | #include "llsaleinfo.h" | 38 | #include "llsaleinfo.h" |
39 | #include "llassetstorage.h" | 39 | #include "llassetstorage.h" |
40 | #include "llwearabletype.h" | ||
40 | 41 | ||
41 | class LLViewerInventoryItem; | 42 | class LLViewerInventoryItem; |
42 | 43 | ||
43 | enum EWearableType // If you change this, update LLWearable::getTypeName(), getTypeLabel(), and LLVOAvatar::getTEWearableType() | ||
44 | { | ||
45 | WT_SHAPE = 0, | ||
46 | WT_SKIN = 1, | ||
47 | WT_HAIR = 2, | ||
48 | WT_EYES = 3, | ||
49 | WT_SHIRT = 4, | ||
50 | WT_PANTS = 5, | ||
51 | WT_SHOES = 6, | ||
52 | WT_SOCKS = 7, | ||
53 | WT_JACKET = 8, | ||
54 | WT_GLOVES = 9, | ||
55 | WT_UNDERSHIRT = 10, | ||
56 | WT_UNDERPANTS = 11, | ||
57 | WT_SKIRT = 12, | ||
58 | WT_COUNT = 13, | ||
59 | WT_INVALID = 255 | ||
60 | }; | ||
61 | |||
62 | class LLWearable | 44 | class LLWearable |
63 | { | 45 | { |
64 | friend class LLWearableList; | 46 | friend class LLWearableList; |
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml b/linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml index 1cb1da0..590555f 100644 --- a/linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml +++ b/linden/indra/newview/skins/default/xui/en-us/floater_inventory.xml | |||
@@ -5,18 +5,64 @@ | |||
5 | title="Inventory" width="467"> | 5 | title="Inventory" width="467"> |
6 | <search_editor bottom="-50" follows="left|top|right" height="16" label="Type here to search" | 6 | <search_editor bottom="-50" follows="left|top|right" height="16" label="Type here to search" |
7 | left="6" mouse_opaque="true" name="inventory search editor" width="455" /> | 7 | left="6" mouse_opaque="true" name="inventory search editor" width="455" /> |
8 | <tab_container bottom_delta="-512" follows="left|top|right|bottom" height="508" left="2" | 8 | |
9 | mouse_opaque="false" name="inventory filter tabs" tab_position="top" | 9 | <text name="group_titles_textbox" font="SansSerifSmall" follows="left|top" |
10 | width="463"> | 10 | height="16" left="10" bottom_delta="-24" width="120"> |
11 | Quick Filter: | ||
12 | </text> | ||
13 | |||
14 | <!-- Inventory Type Filter Labels --> | ||
15 | <string name="filter_type_all">All Types</string> | ||
16 | <string name="filter_type_animation">Animations</string> | ||
17 | <string name="filter_type_bodypart">Body Parts</string> | ||
18 | <string name="filter_type_callingcard">Calling Cards</string> | ||
19 | <string name="filter_type_clothing">Clothing</string> | ||
20 | <string name="filter_type_gesture">Gestures</string> | ||
21 | <string name="filter_type_landmark">Landmarks</string> | ||
22 | <string name="filter_type_notecard">Notecards</string> | ||
23 | <string name="filter_type_object">Objects</string> | ||
24 | <string name="filter_type_script">Scripts</string> | ||
25 | <string name="filter_type_sound">Sounds</string> | ||
26 | <string name="filter_type_texture">Textures</string> | ||
27 | <string name="filter_type_snapshot">Snapshots</string> | ||
28 | <string name="filter_type_custom">Custom...</string> | ||
29 | |||
30 | <combo_box name="Quick Filter" label="Quick Filter" follows="left|top" | ||
31 | height="20" left="80" width="150" bottom_delta="0"> | ||
32 | |||
33 | <combo_item name="filter_type_all">All Types</combo_item> | ||
34 | <separator /> | ||
35 | <combo_item name="filter_type_animation">Animations</combo_item> | ||
36 | <combo_item name="filter_type_bodypart">Body Parts</combo_item> | ||
37 | <combo_item name="filter_type_callingcard">Calling Cards</combo_item> | ||
38 | <combo_item name="filter_type_clothing">Clothing</combo_item> | ||
39 | <combo_item name="filter_type_gesture">Gestures</combo_item> | ||
40 | <combo_item name="filter_type_landmark">Landmarks</combo_item> | ||
41 | <combo_item name="filter_type_notecard">Notecards</combo_item> | ||
42 | <combo_item name="filter_type_object">Objects</combo_item> | ||
43 | <combo_item name="filter_type_script">Scripts</combo_item> | ||
44 | <combo_item name="filter_type_sound">Sounds</combo_item> | ||
45 | <combo_item name="filter_type_texture">Textures</combo_item> | ||
46 | <combo_item name="filter_type_snapshot">Snapshots</combo_item> | ||
47 | <separator /> | ||
48 | <combo_item name="filter_type_custom">Custom...</combo_item> | ||
49 | |||
50 | </combo_box> | ||
51 | |||
52 | <tab_container name="inventory filter tabs" follows="left|top|right|bottom" | ||
53 | bottom_delta="-487" height="480" left="2" width="463" | ||
54 | mouse_opaque="false" tab_position="top"> | ||
55 | |||
11 | <inventory_panel allow_multi_select="true" border="true" bottom="-507" | 56 | <inventory_panel allow_multi_select="true" border="true" bottom="-507" |
12 | follows="left|top|right|bottom" height="491" label="All Items" left="1" | 57 | follows="left|top|right|bottom" height="431" label="All Items" left="1" |
13 | mouse_opaque="true" name="All Items" sort_order="InventorySortOrder" | 58 | mouse_opaque="true" name="All Items" sort_order="InventorySortOrder" |
14 | width="461" /> | 59 | width="461" /> |
15 | <inventory_panel allow_multi_select="true" border="true" bottom_delta="0" | 60 | <inventory_panel allow_multi_select="true" border="true" bottom_delta="0" |
16 | follows="left|top|right|bottom" height="491" label="Recent Items" | 61 | follows="left|top|right|bottom" height="431" label="Recent Items" |
17 | left_delta="0" mouse_opaque="true" name="Recent Items" | 62 | left_delta="0" mouse_opaque="true" name="Recent Items" |
18 | sort_order="RecentItemsSortOrder" width="461" /> | 63 | sort_order="RecentItemsSortOrder" width="461" /> |
19 | </tab_container> | 64 | </tab_container> |
65 | |||
20 | <menu_bar bottom="-34" drop_shadow="false" follows="left|top|right" height="18" left="2" | 66 | <menu_bar bottom="-34" drop_shadow="false" follows="left|top|right" height="18" left="2" |
21 | mouse_opaque="false" name="Inventory Menu" opaque="false" width="461"> | 67 | mouse_opaque="false" name="Inventory Menu" opaque="false" width="461"> |
22 | <menu bottom_delta="16" drop_shadow="true" height="101" | 68 | <menu bottom_delta="16" drop_shadow="true" height="101" |
diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml b/linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml index 9a9b8db..9a5756b 100644 --- a/linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml +++ b/linden/indra/newview/skins/default/xui/en-us/floater_inventory_view_finder.xml | |||
@@ -1,102 +1,133 @@ | |||
1 | <?xml version="1.0" encoding="utf-8" standalone="yes" ?> | 1 | <?xml version="1.0" encoding="utf-8" standalone="yes" ?> |
2 | <floater bottom="-495" can_close="true" can_drag_on_left="false" can_minimize="false" | 2 | |
3 | can_resize="false" can_tear_off="true" enabled="true" height="408" | 3 | <floater name="Inventory Finder" title="inventory_recent_items" |
4 | left="457" min_height="408" min_width="160" mouse_opaque="true" | 4 | bottom="-495" left="457" height="428" width="170" |
5 | name="Inventory Finder" title="inventory_recent_items" width="160"> | 5 | can_close="true" can_drag_on_left="false" can_minimize="false" |
6 | <icon bottom="-36" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 6 | can_resize="false" can_tear_off="true"> |
7 | image_name="inv_item_animation.tga" left="8" mouse_opaque="true" | 7 | |
8 | name="icon_animation" width="16" /> | 8 | |
9 | <check_box bottom="-36" enabled="true" follows="left|top" font="SansSerifSmall" | 9 | <icon name="icon_animation" image_name="inv_item_animation.tga" |
10 | height="16" initial_value="false" label="Animation" left="26" | 10 | bottom="-36" left="8" height="16" width="16" follows="left|top" /> |
11 | mouse_opaque="true" name="check_animation" radio_style="false" width="126" /> | 11 | <check_box label="Animation" name="check_animation" |
12 | <icon bottom="-56" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 12 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
13 | image_name="inv_item_callingcard_online.tga" left="8" mouse_opaque="true" | 13 | font="SansSerifSmall" initial_value="false" /> |
14 | name="icon_calling_card" width="16" /> | 14 | |
15 | <check_box bottom="-56" enabled="true" follows="left|top" font="SansSerifSmall" | 15 | |
16 | height="16" initial_value="false" label="Calling Cards" left="26" | 16 | <icon name="icon_bodypart" image_name="inv_item_skin.tga" |
17 | mouse_opaque="true" name="check_calling_card" radio_style="false" | 17 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
18 | width="126" /> | 18 | <check_box label="Body Parts" name="check_bodypart" |
19 | <icon bottom="-76" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 19 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
20 | image_name="inv_item_shirt.tga" left="8" mouse_opaque="true" | 20 | font="SansSerifSmall" initial_value="false" /> |
21 | name="icon_clothing" width="16" /> | 21 | |
22 | <check_box bottom="-76" enabled="true" follows="left|top" font="SansSerifSmall" | 22 | |
23 | height="16" initial_value="false" label="Clothing" left="26" | 23 | <icon name="icon_calling_card" image_name="inv_item_callingcard_online.tga" |
24 | mouse_opaque="true" name="check_clothing" radio_style="false" width="126" /> | 24 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
25 | <icon bottom="-96" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 25 | <check_box label="Calling Cards" name="check_calling_card" |
26 | image_name="inv_item_gesture.tga" left="8" mouse_opaque="true" | 26 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
27 | name="icon_gesture" width="16" /> | 27 | font="SansSerifSmall" initial_value="false" /> |
28 | <check_box bottom="-96" enabled="true" follows="left|top" font="SansSerifSmall" | 28 | |
29 | height="16" initial_value="false" label="Gestures" left="26" | 29 | |
30 | mouse_opaque="true" name="check_gesture" radio_style="false" width="126" /> | 30 | <icon name="icon_clothing" image_name="inv_item_shirt.tga" |
31 | <icon bottom="-116" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 31 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
32 | image_name="inv_item_landmark_visited.tga" left="8" mouse_opaque="true" | 32 | <check_box label="Clothing" name="check_clothing" |
33 | name="icon_landmark" width="16" /> | 33 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
34 | <check_box bottom="-116" enabled="true" follows="left|top" font="SansSerifSmall" | 34 | font="SansSerifSmall" initial_value="false" /> |
35 | height="16" initial_value="false" label="Landmarks" left="26" | 35 | |
36 | mouse_opaque="true" name="check_landmark" radio_style="false" width="126" /> | 36 | |
37 | <icon bottom="-136" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 37 | <icon name="icon_gesture" image_name="inv_item_gesture.tga" |
38 | image_name="inv_item_notecard.tga" left="8" mouse_opaque="true" | 38 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
39 | name="icon_notecard" width="16" /> | 39 | <check_box label="Gestures" name="check_gesture" |
40 | <check_box bottom="-136" enabled="true" follows="left|top" font="SansSerifSmall" | 40 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
41 | height="16" initial_value="false" label="Notecards" left="26" | 41 | font="SansSerifSmall" initial_value="false" /> |
42 | mouse_opaque="true" name="check_notecard" radio_style="false" width="126" /> | 42 | |
43 | <icon bottom="-156" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 43 | |
44 | image_name="inv_item_object.tga" left="8" mouse_opaque="true" | 44 | <icon name="icon_landmark" image_name="inv_item_landmark_visited.tga" |
45 | name="icon_object" width="16" /> | 45 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
46 | <check_box bottom="-156" enabled="true" follows="left|top" font="SansSerifSmall" | 46 | <check_box label="Landmarks" name="check_landmark" |
47 | height="16" initial_value="false" label="Objects" left="26" | 47 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
48 | mouse_opaque="true" name="check_object" radio_style="false" width="126" /> | 48 | font="SansSerifSmall" initial_value="false" /> |
49 | <icon bottom="-176" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 49 | |
50 | image_name="inv_item_script.tga" left="8" mouse_opaque="true" | 50 | |
51 | name="icon_script" width="16" /> | 51 | <icon name="icon_notecard" image_name="inv_item_notecard.tga" |
52 | <check_box bottom="-176" enabled="true" follows="left|top" font="SansSerifSmall" | 52 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
53 | height="16" initial_value="false" label="Scripts" left="26" | 53 | <check_box label="Notecards" name="check_notecard" |
54 | mouse_opaque="true" name="check_script" radio_style="false" width="126" /> | 54 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
55 | <icon bottom="-196" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 55 | font="SansSerifSmall" initial_value="false" /> |
56 | image_name="inv_item_sound.tga" left="8" mouse_opaque="true" | 56 | |
57 | name="icon_sound" width="16" /> | 57 | |
58 | <check_box bottom="-196" enabled="true" follows="left|top" font="SansSerifSmall" | 58 | <icon name="icon_object" image_name="inv_item_object.tga" |
59 | height="16" initial_value="false" label="Sounds" left="26" | 59 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
60 | mouse_opaque="true" name="check_sound" radio_style="false" width="126" /> | 60 | <check_box label="Objects" name="check_object" |
61 | <icon bottom="-216" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 61 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
62 | image_name="inv_item_texture.tga" left="8" mouse_opaque="true" | 62 | font="SansSerifSmall" initial_value="false" /> |
63 | name="icon_texture" width="16" /> | 63 | |
64 | <check_box bottom="-216" enabled="true" follows="left|top" font="SansSerifSmall" | 64 | |
65 | height="16" initial_value="false" label="Textures" left="26" | 65 | <icon name="icon_script" image_name="inv_item_script.tga" |
66 | mouse_opaque="true" name="check_texture" radio_style="false" width="126" /> | 66 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
67 | <icon bottom="-236" color="1 1 1 1" enabled="true" follows="left|top" height="16" | 67 | <check_box label="Scripts" name="check_script" |
68 | image_name="inv_item_snapshot.tga" left="8" mouse_opaque="true" | 68 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
69 | name="icon_snapshot" width="16" /> | 69 | font="SansSerifSmall" initial_value="false" /> |
70 | <check_box bottom="-236" enabled="true" follows="left|top" font="SansSerifSmall" | 70 | |
71 | height="16" initial_value="false" label="Snapshots" left="26" | 71 | |
72 | mouse_opaque="true" name="check_snapshot" radio_style="false" width="126" /> | 72 | <icon name="icon_sound" image_name="inv_item_sound.tga" |
73 | <button bottom="-260" enabled="true" follows="left|top" font="SansSerif" | 73 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
74 | halign="center" height="20" label="All" label_selected="All" left="8" | 74 | <check_box label="Sounds" name="check_sound" |
75 | mouse_opaque="true" name="All" scale_image="true" width="100" /> | 75 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
76 | <button bottom="-284" enabled="true" follows="left|top" font="SansSerif" | 76 | font="SansSerifSmall" initial_value="false" /> |
77 | halign="center" height="20" label="None" label_selected="None" left="8" | 77 | |
78 | mouse_opaque="true" name="None" scale_image="true" width="100" /> | 78 | |
79 | <check_box bottom="-304" enabled="true" follows="left|top" font="SansSerifSmall" | 79 | <icon name="icon_texture" image_name="inv_item_texture.tga" |
80 | height="16" initial_value="false" label="Always show folders" left="8" | 80 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
81 | mouse_opaque="true" name="check_show_empty" radio_style="false" width="144" /> | 81 | <check_box label="Textures" name="check_texture" |
82 | <check_box bottom="-324" enabled="true" follows="left|top" font="SansSerifSmall" | 82 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
83 | height="16" initial_value="false" label="Since Logoff" left="8" | 83 | font="SansSerifSmall" initial_value="false" /> |
84 | mouse_opaque="true" name="check_since_logoff" radio_style="false" | 84 | |
85 | width="144" /> | 85 | |
86 | <text type="string" length="1" bg_visible="false" border_drop_shadow_visible="false" border_visible="false" | 86 | <icon name="icon_snapshot" image_name="inv_item_snapshot.tga" |
87 | bottom="-336" drop_shadow_visible="true" enabled="true" follows="left|top" | 87 | bottom_delta="-20" left="8" height="16" width="16" follows="left|top" /> |
88 | font="SansSerifSmall" h_pad="0" halign="center" height="12" left="8" | 88 | <check_box label="Snapshots" name="check_snapshot" |
89 | mouse_opaque="true" name="- OR -" v_pad="0" width="144"> | 89 | bottom_delta="0" left="26" height="16" width="126" follows="left|top" |
90 | font="SansSerifSmall" initial_value="false" /> | ||
91 | |||
92 | |||
93 | <button label="All" label_selected="All" name="All" | ||
94 | bottom_delta="-24" left="8" height="20" width="100" follows="left|top" | ||
95 | font="SansSerif" halign="center" scale_image="true" /> | ||
96 | |||
97 | <button label="None" label_selected="None" name="None" | ||
98 | bottom_delta="-24" left="8" height="20" width="100" follows="left|top" | ||
99 | font="SansSerif" halign="center" scale_image="true" /> | ||
100 | |||
101 | |||
102 | <check_box label="Always show folders" name="check_show_empty" | ||
103 | bottom_delta="-20" left="8" height="16" width="144" follows="left|top" | ||
104 | font="SansSerifSmall" initial_value="false" /> | ||
105 | |||
106 | |||
107 | <check_box label="Since Logoff" name="check_since_logoff" | ||
108 | bottom_delta="-20" left="8" height="16" width="144" follows="left|top" | ||
109 | font="SansSerifSmall" initial_value="false" /> | ||
110 | |||
111 | |||
112 | <text name="- OR -" type="string" length="1" | ||
113 | bottom_delta="-12" left="8" height="12" width="144" follows="left|top" | ||
114 | halign="center" h_pad="0" v_pad="0" | ||
115 | bg_visible="false" border_drop_shadow_visible="false" | ||
116 | border_visible="false" drop_shadow_visible="true" | ||
117 | font="SansSerifSmall"> | ||
90 | - OR - | 118 | - OR - |
91 | </text> | 119 | </text> |
92 | <spinner bottom="-356" enabled="true" follows="left|top" height="16" increment="1" | 120 | |
93 | initial_val="0" label="Hours Ago" label_width="64" left="8" | 121 | |
94 | max_val="240000" min_val="0" mouse_opaque="true" name="spin_hours_ago" | 122 | <spinner label="Hours Ago" label_width="64" name="spin_hours_ago" |
95 | width="144" /> | 123 | bottom_delta="-20" left="8" height="16" width="144" follows="left|top" |
96 | <spinner bottom="-376" enabled="true" follows="left|top" height="16" increment="1" | 124 | increment="1" initial_val="0" max_val="240000" min_val="0" /> |
97 | initial_val="0" label="Days Ago" label_width="64" left="8" max_val="10000" | 125 | <spinner label="Days Ago" label_width="64" name="spin_days_ago" |
98 | min_val="0" mouse_opaque="true" name="spin_days_ago" width="144" /> | 126 | bottom_delta="-20" left="8" width="144" height="16" follows="left|top" |
99 | <button bottom="-400" enabled="true" follows="top|right" font="SansSerif" | 127 | increment="1" initial_val="0" max_val="10000" min_val="0" /> |
100 | halign="center" height="20" label="Close" label_selected="Close" | 128 | |
101 | mouse_opaque="true" name="Close" right="-6" scale_image="true" width="76" /> | 129 | |
130 | <button label="Close" label_selected="Close" name="Close" | ||
131 | bottom="-420" right="-6" height="20" width="76" follows="top|right" | ||
132 | font="SansSerif" halign="center" scale_image="true" /> | ||
102 | </floater> | 133 | </floater> |