diff options
Diffstat (limited to 'linden/indra/newview/llfloaterproperties.cpp')
-rw-r--r-- | linden/indra/newview/llfloaterproperties.cpp | 39 |
1 files changed, 19 insertions, 20 deletions
diff --git a/linden/indra/newview/llfloaterproperties.cpp b/linden/indra/newview/llfloaterproperties.cpp index 3519520..0d2cd5f 100644 --- a/linden/indra/newview/llfloaterproperties.cpp +++ b/linden/indra/newview/llfloaterproperties.cpp | |||
@@ -56,7 +56,7 @@ | |||
56 | #include "llviewerregion.h" | 56 | #include "llviewerregion.h" |
57 | #include "llviewercontrol.h" | 57 | #include "llviewercontrol.h" |
58 | 58 | ||
59 | #include "llvieweruictrlfactory.h" | 59 | #include "lluictrlfactory.h" |
60 | 60 | ||
61 | 61 | ||
62 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 62 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
@@ -65,7 +65,7 @@ | |||
65 | // helper class to watch the inventory. | 65 | // helper class to watch the inventory. |
66 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 66 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
67 | 67 | ||
68 | class LLPropertiesObserver : public LLInventoryObserver | 68 | class LLPropertiesObserver : public LLInventoryObserver, public LLSingleton<LLPropertiesObserver> |
69 | { | 69 | { |
70 | public: | 70 | public: |
71 | LLPropertiesObserver() {} | 71 | LLPropertiesObserver() {} |
@@ -73,7 +73,6 @@ public: | |||
73 | virtual void changed(U32 mask); | 73 | virtual void changed(U32 mask); |
74 | }; | 74 | }; |
75 | 75 | ||
76 | LLPropertiesObserver* gPropertiesObserver = NULL; | ||
77 | void LLPropertiesObserver::changed(U32 mask) | 76 | void LLPropertiesObserver::changed(U32 mask) |
78 | { | 77 | { |
79 | // if there's a change we're interested in. | 78 | // if there's a change we're interested in. |
@@ -144,13 +143,13 @@ LLFloaterProperties::LLFloaterProperties(const std::string& name, const LLRect& | |||
144 | mObjectID(object_id), | 143 | mObjectID(object_id), |
145 | mDirty(TRUE) | 144 | mDirty(TRUE) |
146 | { | 145 | { |
147 | gUICtrlFactory->buildFloater(this,"floater_inventory_item_properties.xml"); | 146 | LLUICtrlFactory::getInstance()->buildFloater(this,"floater_inventory_item_properties.xml"); |
148 | 147 | ||
149 | // hack to make sure these floaters are observing the inventory. | 148 | // hack to make sure these floaters are observing the inventory. |
150 | if(!gPropertiesObserver) | 149 | if(!gInventory.containsObserver(LLPropertiesObserver::getInstance())) |
151 | { | 150 | { |
152 | gPropertiesObserver = new LLPropertiesObserver; | 151 | // Note: this is where gPropertiesObserver used to be constructed. |
153 | gInventory.addObserver(gPropertiesObserver); | 152 | gInventory.addObserver(LLPropertiesObserver::getInstance()); |
154 | } | 153 | } |
155 | // add the object to the static structure | 154 | // add the object to the static structure |
156 | LLUUID key = mItemID ^ mObjectID; | 155 | LLUUID key = mItemID ^ mObjectID; |
@@ -473,7 +472,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) | |||
473 | { | 472 | { |
474 | childSetValue("CheckShareWithGroup",LLSD((BOOL)TRUE)); | 473 | childSetValue("CheckShareWithGroup",LLSD((BOOL)TRUE)); |
475 | 474 | ||
476 | LLCheckBoxCtrl* ctl = LLUICtrlFactory::getCheckBoxByName(this,"CheckShareWithGroup"); | 475 | LLCheckBoxCtrl* ctl = getChild<LLCheckBoxCtrl>("CheckShareWithGroup"); |
477 | if(ctl) | 476 | if(ctl) |
478 | { | 477 | { |
479 | ctl->setTentative(FALSE); | 478 | ctl->setTentative(FALSE); |
@@ -482,7 +481,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) | |||
482 | else if (!is_group_copy && !is_group_modify && !is_group_move) | 481 | else if (!is_group_copy && !is_group_modify && !is_group_move) |
483 | { | 482 | { |
484 | childSetValue("CheckShareWithGroup",LLSD((BOOL)FALSE)); | 483 | childSetValue("CheckShareWithGroup",LLSD((BOOL)FALSE)); |
485 | LLCheckBoxCtrl* ctl = LLUICtrlFactory::getCheckBoxByName(this,"CheckShareWithGroup"); | 484 | LLCheckBoxCtrl* ctl = getChild<LLCheckBoxCtrl>("CheckShareWithGroup"); |
486 | if(ctl) | 485 | if(ctl) |
487 | { | 486 | { |
488 | ctl->setTentative(FALSE); | 487 | ctl->setTentative(FALSE); |
@@ -490,7 +489,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) | |||
490 | } | 489 | } |
491 | else | 490 | else |
492 | { | 491 | { |
493 | LLCheckBoxCtrl* ctl = LLUICtrlFactory::getCheckBoxByName(this,"CheckShareWithGroup"); | 492 | LLCheckBoxCtrl* ctl = getChild<LLCheckBoxCtrl>("CheckShareWithGroup"); |
494 | if(ctl) | 493 | if(ctl) |
495 | { | 494 | { |
496 | ctl->setTentative(TRUE); | 495 | ctl->setTentative(TRUE); |
@@ -543,7 +542,7 @@ void LLFloaterProperties::refreshFromItem(LLInventoryItem* item) | |||
543 | childSetValue("CheckNextOwnerCopy",LLSD(BOOL(next_owner_mask & PERM_COPY))); | 542 | childSetValue("CheckNextOwnerCopy",LLSD(BOOL(next_owner_mask & PERM_COPY))); |
544 | childSetValue("CheckNextOwnerTransfer",LLSD(BOOL(next_owner_mask & PERM_TRANSFER))); | 543 | childSetValue("CheckNextOwnerTransfer",LLSD(BOOL(next_owner_mask & PERM_TRANSFER))); |
545 | 544 | ||
546 | LLRadioGroup* radioSaleType = LLUICtrlFactory::getRadioGroupByName(this,"RadioSaleType"); | 545 | LLRadioGroup* radioSaleType = getChild<LLRadioGroup>("RadioSaleType"); |
547 | if (is_for_sale) | 546 | if (is_for_sale) |
548 | { | 547 | { |
549 | radioSaleType->setSelectedIndex((S32)sale_info.getSaleType() - 1); | 548 | radioSaleType->setSelectedIndex((S32)sale_info.getSaleType() - 1); |
@@ -605,7 +604,7 @@ void LLFloaterProperties::onCommitName(LLUICtrl* ctrl, void* data) | |||
605 | { | 604 | { |
606 | return; | 605 | return; |
607 | } | 606 | } |
608 | LLLineEditor* labelItemName = LLUICtrlFactory::getLineEditorByName(self,"LabelItemName"); | 607 | LLLineEditor* labelItemName = self->getChild<LLLineEditor>("LabelItemName"); |
609 | 608 | ||
610 | if(labelItemName&& | 609 | if(labelItemName&& |
611 | (item->getName() != labelItemName->getText()) && | 610 | (item->getName() != labelItemName->getText()) && |
@@ -642,7 +641,7 @@ void LLFloaterProperties::onCommitDescription(LLUICtrl* ctrl, void* data) | |||
642 | LLViewerInventoryItem* item = (LLViewerInventoryItem*)self->findItem(); | 641 | LLViewerInventoryItem* item = (LLViewerInventoryItem*)self->findItem(); |
643 | if(!item) return; | 642 | if(!item) return; |
644 | 643 | ||
645 | LLLineEditor* labelItemDesc = LLUICtrlFactory::getLineEditorByName(self,"LabelItemDesc"); | 644 | LLLineEditor* labelItemDesc = self->getChild<LLLineEditor>("LabelItemDesc"); |
646 | if(!labelItemDesc) | 645 | if(!labelItemDesc) |
647 | { | 646 | { |
648 | return; | 647 | return; |
@@ -684,7 +683,7 @@ void LLFloaterProperties::onCommitPermissions(LLUICtrl* ctrl, void* data) | |||
684 | LLPermissions perm(item->getPermissions()); | 683 | LLPermissions perm(item->getPermissions()); |
685 | 684 | ||
686 | 685 | ||
687 | LLCheckBoxCtrl* CheckShareWithGroup = LLUICtrlFactory::getCheckBoxByName(self,"CheckShareWithGroup"); | 686 | LLCheckBoxCtrl* CheckShareWithGroup = self->getChild<LLCheckBoxCtrl>("CheckShareWithGroup"); |
688 | 687 | ||
689 | if(CheckShareWithGroup) | 688 | if(CheckShareWithGroup) |
690 | { | 689 | { |
@@ -692,26 +691,26 @@ void LLFloaterProperties::onCommitPermissions(LLUICtrl* ctrl, void* data) | |||
692 | CheckShareWithGroup->get(), | 691 | CheckShareWithGroup->get(), |
693 | PERM_MODIFY | PERM_MOVE | PERM_COPY); | 692 | PERM_MODIFY | PERM_MOVE | PERM_COPY); |
694 | } | 693 | } |
695 | LLCheckBoxCtrl* CheckEveryoneCopy = LLUICtrlFactory::getCheckBoxByName(self,"CheckEveryoneCopy"); | 694 | LLCheckBoxCtrl* CheckEveryoneCopy = self->getChild<LLCheckBoxCtrl>("CheckEveryoneCopy"); |
696 | if(CheckEveryoneCopy) | 695 | if(CheckEveryoneCopy) |
697 | { | 696 | { |
698 | perm.setEveryoneBits(gAgent.getID(), gAgent.getGroupID(), | 697 | perm.setEveryoneBits(gAgent.getID(), gAgent.getGroupID(), |
699 | CheckEveryoneCopy->get(), PERM_COPY); | 698 | CheckEveryoneCopy->get(), PERM_COPY); |
700 | } | 699 | } |
701 | 700 | ||
702 | LLCheckBoxCtrl* CheckNextOwnerModify = LLUICtrlFactory::getCheckBoxByName(self,"CheckNextOwnerModify"); | 701 | LLCheckBoxCtrl* CheckNextOwnerModify = self->getChild<LLCheckBoxCtrl>("CheckNextOwnerModify"); |
703 | if(CheckNextOwnerModify) | 702 | if(CheckNextOwnerModify) |
704 | { | 703 | { |
705 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), | 704 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), |
706 | CheckNextOwnerModify->get(), PERM_MODIFY); | 705 | CheckNextOwnerModify->get(), PERM_MODIFY); |
707 | } | 706 | } |
708 | LLCheckBoxCtrl* CheckNextOwnerCopy = LLUICtrlFactory::getCheckBoxByName(self,"CheckNextOwnerCopy"); | 707 | LLCheckBoxCtrl* CheckNextOwnerCopy = self->getChild<LLCheckBoxCtrl>("CheckNextOwnerCopy"); |
709 | if(CheckNextOwnerCopy) | 708 | if(CheckNextOwnerCopy) |
710 | { | 709 | { |
711 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), | 710 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), |
712 | CheckNextOwnerCopy->get(), PERM_COPY); | 711 | CheckNextOwnerCopy->get(), PERM_COPY); |
713 | } | 712 | } |
714 | LLCheckBoxCtrl* CheckNextOwnerTransfer = LLUICtrlFactory::getCheckBoxByName(self,"CheckNextOwnerTransfer"); | 713 | LLCheckBoxCtrl* CheckNextOwnerTransfer = self->getChild<LLCheckBoxCtrl>("CheckNextOwnerTransfer"); |
715 | if(CheckNextOwnerTransfer) | 714 | if(CheckNextOwnerTransfer) |
716 | { | 715 | { |
717 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), | 716 | perm.setNextOwnerBits(gAgent.getID(), gAgent.getGroupID(), |
@@ -805,7 +804,7 @@ void LLFloaterProperties::updateSaleInfo() | |||
805 | // turn on sale info | 804 | // turn on sale info |
806 | LLSaleInfo::EForSale sale_type = LLSaleInfo::FS_COPY; | 805 | LLSaleInfo::EForSale sale_type = LLSaleInfo::FS_COPY; |
807 | 806 | ||
808 | LLRadioGroup* RadioSaleType = LLUICtrlFactory::getRadioGroupByName(this,"RadioSaleType"); | 807 | LLRadioGroup* RadioSaleType = getChild<LLRadioGroup>("RadioSaleType"); |
809 | if(RadioSaleType) | 808 | if(RadioSaleType) |
810 | { | 809 | { |
811 | switch (RadioSaleType->getSelectedIndex()) | 810 | switch (RadioSaleType->getSelectedIndex()) |
@@ -832,7 +831,7 @@ void LLFloaterProperties::updateSaleInfo() | |||
832 | sale_type = LLSaleInfo::FS_ORIGINAL; | 831 | sale_type = LLSaleInfo::FS_ORIGINAL; |
833 | } | 832 | } |
834 | 833 | ||
835 | LLLineEditor* EditPrice = LLUICtrlFactory::getLineEditorByName(this,"EditPrice"); | 834 | LLLineEditor* EditPrice = getChild<LLLineEditor>("EditPrice"); |
836 | 835 | ||
837 | S32 price = -1; | 836 | S32 price = -1; |
838 | if(EditPrice) | 837 | if(EditPrice) |