aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui')
-rw-r--r--linden/indra/llui/llalertdialog.h9
-rw-r--r--linden/indra/llui/llcombobox.cpp2
-rw-r--r--linden/indra/llui/llctrlselectioninterface.cpp1
-rw-r--r--linden/indra/llui/lleditmenuhandler.cpp2
-rw-r--r--linden/indra/llui/lllineeditor.cpp23
-rw-r--r--linden/indra/llui/llrootview.cpp1
-rw-r--r--linden/indra/llui/llscrollcontainer.cpp19
-rw-r--r--linden/indra/llui/llscrollcontainer.h12
-rw-r--r--linden/indra/llui/llscrolllistctrl.cpp15
-rw-r--r--linden/indra/llui/llscrolllistctrl.h2
-rw-r--r--linden/indra/llui/lltabcontainer.cpp81
-rw-r--r--linden/indra/llui/lltabcontainer.h6
-rw-r--r--linden/indra/llui/lltexteditor.cpp21
-rw-r--r--linden/indra/llui/llviewquery.cpp2
14 files changed, 140 insertions, 56 deletions
diff --git a/linden/indra/llui/llalertdialog.h b/linden/indra/llui/llalertdialog.h
index d389236..1add4a4 100644
--- a/linden/indra/llui/llalertdialog.h
+++ b/linden/indra/llui/llalertdialog.h
@@ -162,6 +162,15 @@ public:
162 return FALSE; 162 return FALSE;
163 } 163 }
164 } 164 }
165
166 void setIgnore(bool state)
167 {
168 if (mIgnorable)
169 {
170 LLAlertDialog::sSettings->setWarning(mIgnoreLabel, !state);
171 }
172 }
173
165 174
166public: 175public:
167 LLString mLabel; // Handle for access from code, etc 176 LLString mLabel; // Handle for access from code, etc
diff --git a/linden/indra/llui/llcombobox.cpp b/linden/indra/llui/llcombobox.cpp
index e00454a..27df619 100644
--- a/linden/indra/llui/llcombobox.cpp
+++ b/linden/indra/llui/llcombobox.cpp
@@ -66,8 +66,8 @@ LLComboBox::LLComboBox( const LLString& name, const LLRect &rect, const LLString
66 mAllowTextEntry(FALSE), 66 mAllowTextEntry(FALSE),
67 mMaxChars(20), 67 mMaxChars(20),
68 mTextEntryTentative(TRUE), 68 mTextEntryTentative(TRUE),
69 mPrearrangeCallback( NULL ),
70 mListPosition(BELOW), 69 mListPosition(BELOW),
70 mPrearrangeCallback( NULL ),
71 mTextEntryCallback( NULL ) 71 mTextEntryCallback( NULL )
72{ 72{
73 // For now, all comboboxes don't take keyboard focus when clicked. 73 // For now, all comboboxes don't take keyboard focus when clicked.
diff --git a/linden/indra/llui/llctrlselectioninterface.cpp b/linden/indra/llui/llctrlselectioninterface.cpp
index 3b71942..d3b83a2 100644
--- a/linden/indra/llui/llctrlselectioninterface.cpp
+++ b/linden/indra/llui/llctrlselectioninterface.cpp
@@ -25,6 +25,7 @@
25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, 25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
26 * COMPLETENESS OR PERFORMANCE. 26 * COMPLETENESS OR PERFORMANCE.
27 */ 27 */
28#include "linden_common.h"
28 29
29#include "llctrlselectioninterface.h" 30#include "llctrlselectioninterface.h"
30 31
diff --git a/linden/indra/llui/lleditmenuhandler.cpp b/linden/indra/llui/lleditmenuhandler.cpp
index 85b4464..559cef4 100644
--- a/linden/indra/llui/lleditmenuhandler.cpp
+++ b/linden/indra/llui/lleditmenuhandler.cpp
@@ -26,7 +26,7 @@
26 * COMPLETENESS OR PERFORMANCE. 26 * COMPLETENESS OR PERFORMANCE.
27*/ 27*/
28 28
29#include "stdtypes.h" 29#include "linden_common.h"
30 30
31#include "lleditmenuhandler.h" 31#include "lleditmenuhandler.h"
32 32
diff --git a/linden/indra/llui/lllineeditor.cpp b/linden/indra/llui/lllineeditor.cpp
index 44616b9..98286fa 100644
--- a/linden/indra/llui/lllineeditor.cpp
+++ b/linden/indra/llui/lllineeditor.cpp
@@ -220,6 +220,9 @@ LLString LLLineEditor::getWidgetTag() const
220 220
221void LLLineEditor::onFocusLost() 221void LLLineEditor::onFocusLost()
222{ 222{
223 // Need to notify early when loosing focus.
224 getWindow()->allowLanguageTextInput(FALSE);
225
223 LLUICtrl::onFocusLost(); 226 LLUICtrl::onFocusLost();
224 227
225 if( mCommitOnFocusLost && mText.getString() != mPrevText) 228 if( mCommitOnFocusLost && mText.getString() != mPrevText)
@@ -1130,7 +1133,7 @@ BOOL LLLineEditor::handleSpecialKey(KEY key, MASK mask)
1130 1133
1131 // handle ctrl-uparrow if we have a history enabled line editor. 1134 // handle ctrl-uparrow if we have a history enabled line editor.
1132 case KEY_UP: 1135 case KEY_UP:
1133 if( mHaveHistory && ( MASK_CONTROL & mask ) ) 1136 if( mHaveHistory && ( MASK_CONTROL == mask ) )
1134 { 1137 {
1135 if( mCurrentHistoryLine > 0 ) 1138 if( mCurrentHistoryLine > 0 )
1136 { 1139 {
@@ -1147,7 +1150,7 @@ BOOL LLLineEditor::handleSpecialKey(KEY key, MASK mask)
1147 1150
1148 // handle ctrl-downarrow if we have a history enabled line editor 1151 // handle ctrl-downarrow if we have a history enabled line editor
1149 case KEY_DOWN: 1152 case KEY_DOWN:
1150 if( mHaveHistory && ( MASK_CONTROL & mask ) ) 1153 if( mHaveHistory && ( MASK_CONTROL == mask ) )
1151 { 1154 {
1152 if( !mLineHistory.empty() && mCurrentHistoryLine < mLineHistory.size() - 1 ) 1155 if( !mLineHistory.empty() && mCurrentHistoryLine < mLineHistory.size() - 1 )
1153 { 1156 {
@@ -1646,6 +1649,12 @@ void LLLineEditor::setFocus( BOOL new_state )
1646{ 1649{
1647 BOOL old_state = hasFocus(); 1650 BOOL old_state = hasFocus();
1648 1651
1652 if (!new_state)
1653 {
1654 getWindow()->allowLanguageTextInput(FALSE);
1655 }
1656
1657
1649 // getting focus when we didn't have it before, and we want to select all 1658 // getting focus when we didn't have it before, and we want to select all
1650 if (!old_state && new_state && mSelectAllonFocusReceived) 1659 if (!old_state && new_state && mSelectAllonFocusReceived)
1651 { 1660 {
@@ -1676,6 +1685,16 @@ void LLLineEditor::setFocus( BOOL new_state )
1676 } 1685 }
1677 1686
1678 LLUICtrl::setFocus( new_state ); 1687 LLUICtrl::setFocus( new_state );
1688
1689 if (new_state)
1690 {
1691 // Allow Language Text Input only when this LineEditor has
1692 // no prevalidate function attached. This criterion works
1693 // fine on 1.15.0.2, since all prevalidate func reject any
1694 // non-ASCII characters. I'm not sure on future versions,
1695 // however.
1696 getWindow()->allowLanguageTextInput(mPrevalidateFunc == NULL);
1697 }
1679} 1698}
1680 1699
1681//virtual 1700//virtual
diff --git a/linden/indra/llui/llrootview.cpp b/linden/indra/llui/llrootview.cpp
index d78244d..bf231f1 100644
--- a/linden/indra/llui/llrootview.cpp
+++ b/linden/indra/llui/llrootview.cpp
@@ -25,6 +25,7 @@
25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, 25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
26 * COMPLETENESS OR PERFORMANCE. 26 * COMPLETENESS OR PERFORMANCE.
27 */ 27 */
28#include "linden_common.h"
28 29
29#include "llrootview.h" 30#include "llrootview.h"
30 31
diff --git a/linden/indra/llui/llscrollcontainer.cpp b/linden/indra/llui/llscrollcontainer.cpp
index cf43ee1..be41aa8 100644
--- a/linden/indra/llui/llscrollcontainer.cpp
+++ b/linden/indra/llui/llscrollcontainer.cpp
@@ -292,7 +292,26 @@ BOOL LLScrollableContainerView::handleScrollWheel( S32 x, S32 y, S32 clicks )
292 // Opaque 292 // Opaque
293 return TRUE; 293 return TRUE;
294} 294}
295BOOL LLScrollableContainerView::needsToScroll(S32 x, S32 y, LLScrollableContainerView::SCROLL_ORIENTATION axis)
296{
297 if(mScrollbar[axis]->getVisible())
298 {
299 LLRect inner_rect_local( 0, mInnerRect.getHeight(), mInnerRect.getWidth(), 0 );
300 const S32 AUTOSCROLL_SIZE = 10;
301 if(mScrollbar[axis]->getVisible())
302 {
303 inner_rect_local.mRight -= SCROLLBAR_SIZE;
304 inner_rect_local.mTop += AUTOSCROLL_SIZE;
305 inner_rect_local.mBottom = inner_rect_local.mTop - AUTOSCROLL_SIZE;
306 }
307 if( inner_rect_local.pointInRect( x, y ) && (mScrollbar[axis]->getDocPos() > 0) )
308 {
309 return TRUE;
310 }
295 311
312 }
313 return FALSE;
314}
296BOOL LLScrollableContainerView::handleDragAndDrop(S32 x, S32 y, MASK mask, 315BOOL LLScrollableContainerView::handleDragAndDrop(S32 x, S32 y, MASK mask,
297 BOOL drop, 316 BOOL drop,
298 EDragAndDropType cargo_type, 317 EDragAndDropType cargo_type,
diff --git a/linden/indra/llui/llscrollcontainer.h b/linden/indra/llui/llscrollcontainer.h
index 3b3bbef..34fff9c 100644
--- a/linden/indra/llui/llscrollcontainer.h
+++ b/linden/indra/llui/llscrollcontainer.h
@@ -35,6 +35,7 @@
35#endif 35#endif
36#include "stdenums.h" 36#include "stdenums.h"
37#include "llcoord.h" 37#include "llcoord.h"
38#include "llscrollbar.h"
38 39
39//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 40//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
40// Class LLScrollableContainerView 41// Class LLScrollableContainerView
@@ -47,7 +48,6 @@
47// This class is a decorator class. 48// This class is a decorator class.
48//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 49//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
49 50
50class LLScrollbar;
51class LLViewBorder; 51class LLViewBorder;
52class LLUICtrlFactory; 52class LLUICtrlFactory;
53 53
@@ -55,6 +55,10 @@ class LLUICtrlFactory;
55class LLScrollableContainerView : public LLUICtrl 55class LLScrollableContainerView : public LLUICtrl
56{ 56{
57public: 57public:
58 // Note: vertical comes before horizontal because vertical
59 // scrollbars have priority for mouse and keyboard events.
60 enum SCROLL_ORIENTATION { VERTICAL, HORIZONTAL, SCROLLBAR_COUNT };
61
58 LLScrollableContainerView( const LLString& name, const LLRect& rect, 62 LLScrollableContainerView( const LLString& name, const LLRect& rect,
59 LLView* scrolled_view, BOOL is_opaque = FALSE, 63 LLView* scrolled_view, BOOL is_opaque = FALSE,
60 const LLColor4& bg_color = LLColor4(0,0,0,0) ); 64 const LLColor4& bg_color = LLColor4(0,0,0,0) );
@@ -88,6 +92,8 @@ public:
88 void goToBottom(); 92 void goToBottom();
89 S32 getBorderWidth(); 93 S32 getBorderWidth();
90 94
95 BOOL needsToScroll(S32 x, S32 y, SCROLL_ORIENTATION axis);
96
91 // LLView functionality 97 // LLView functionality
92 virtual void reshape(S32 width, S32 height, BOOL called_from_parent); 98 virtual void reshape(S32 width, S32 height, BOOL called_from_parent);
93 virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); 99 virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent);
@@ -110,10 +116,6 @@ protected:
110 virtual void scrollVertical( S32 new_pos ); 116 virtual void scrollVertical( S32 new_pos );
111 void updateScroll(); 117 void updateScroll();
112 118
113 // Note: vertical comes before horizontal because vertical
114 // scrollbars have priority for mouse and keyboard events.
115 enum { VERTICAL, HORIZONTAL, SCROLLBAR_COUNT };
116
117 LLScrollbar* mScrollbar[SCROLLBAR_COUNT]; 119 LLScrollbar* mScrollbar[SCROLLBAR_COUNT];
118 LLView* mScrolledView; 120 LLView* mScrolledView;
119 S32 mSize; 121 S32 mSize;
diff --git a/linden/indra/llui/llscrolllistctrl.cpp b/linden/indra/llui/llscrolllistctrl.cpp
index fd98bd5..5571d39 100644
--- a/linden/indra/llui/llscrolllistctrl.cpp
+++ b/linden/indra/llui/llscrolllistctrl.cpp
@@ -98,8 +98,10 @@ protected:
98// 98//
99// LLScrollListIcon 99// LLScrollListIcon
100// 100//
101LLScrollListIcon::LLScrollListIcon(LLImageGL* icon, S32 width, LLUUID image_id) : 101LLScrollListIcon::LLScrollListIcon(LLImageGL* icon, S32 width, LLUUID image_id)
102mIcon(icon), mColor(LLColor4::white), mImageUUID(image_id.asString()) 102 : mIcon(icon),
103 mImageUUID(image_id.asString()),
104 mColor(LLColor4::white)
103{ 105{
104 if (width) 106 if (width)
105 { 107 {
@@ -431,21 +433,20 @@ LLScrollListCtrl::LLScrollListCtrl(const LLString& name, const LLRect& rect,
431 mFgUnselectedColor( LLUI::sColorsGroup->getColor("ScrollUnselectedColor") ), 433 mFgUnselectedColor( LLUI::sColorsGroup->getColor("ScrollUnselectedColor") ),
432 mFgDisabledColor( LLUI::sColorsGroup->getColor("ScrollDisabledColor") ), 434 mFgDisabledColor( LLUI::sColorsGroup->getColor("ScrollDisabledColor") ),
433 mHighlightedColor( LLUI::sColorsGroup->getColor("ScrollHighlightedColor") ), 435 mHighlightedColor( LLUI::sColorsGroup->getColor("ScrollHighlightedColor") ),
434 mHighlightedItem(-1),
435 mBorderThickness( 2 ), 436 mBorderThickness( 2 ),
436 mOnDoubleClickCallback( NULL ), 437 mOnDoubleClickCallback( NULL ),
437 mOnMaximumSelectCallback( NULL ), 438 mOnMaximumSelectCallback( NULL ),
438 mOnSortChangedCallback( NULL ), 439 mOnSortChangedCallback( NULL ),
439 mDrewSelected(FALSE), 440 mHighlightedItem(-1),
440 mBorder(NULL), 441 mBorder(NULL),
441 mSearchColumn(0),
442 mDefaultColumn("SIMPLE"), 442 mDefaultColumn("SIMPLE"),
443 443 mSearchColumn(0),
444 mNumDynamicWidthColumns(0), 444 mNumDynamicWidthColumns(0),
445 mTotalStaticColumnWidth(0), 445 mTotalStaticColumnWidth(0),
446 mSortColumn(-1), 446 mSortColumn(-1),
447 mSortAscending(TRUE),
447 mSorted(TRUE), 448 mSorted(TRUE),
448 mSortAscending(TRUE) 449 mDrewSelected(FALSE)
449{ 450{
450 mItemListRect.setOriginAndSize( 451 mItemListRect.setOriginAndSize(
451 mBorderThickness + LIST_BORDER_PAD, 452 mBorderThickness + LIST_BORDER_PAD,
diff --git a/linden/indra/llui/llscrolllistctrl.h b/linden/indra/llui/llscrolllistctrl.h
index 429985b..9829832 100644
--- a/linden/indra/llui/llscrolllistctrl.h
+++ b/linden/indra/llui/llscrolllistctrl.h
@@ -328,7 +328,7 @@ public:
328 328
329 S32 getNumColumns() const { return mColumns.size(); } 329 S32 getNumColumns() const { return mColumns.size(); }
330 330
331 LLScrollListCell *getColumn(const S32 i) const { if (i < (S32)mColumns.size()) { return mColumns[i]; } return NULL; } 331 LLScrollListCell *getColumn(const S32 i) const { if (0 <= i && i < (S32)mColumns.size()) { return mColumns[i]; } return NULL; }
332 332
333 virtual BOOL handleClick(S32 x, S32 y, MASK mask); 333 virtual BOOL handleClick(S32 x, S32 y, MASK mask);
334 334
diff --git a/linden/indra/llui/lltabcontainer.cpp b/linden/indra/llui/lltabcontainer.cpp
index 44940ae..01c06c3 100644
--- a/linden/indra/llui/lltabcontainer.cpp
+++ b/linden/indra/llui/lltabcontainer.cpp
@@ -51,6 +51,7 @@
51#include "llglheaders.h" 51#include "llglheaders.h"
52 52
53const F32 SCROLL_STEP_TIME = 0.4f; 53const F32 SCROLL_STEP_TIME = 0.4f;
54const F32 SCROLL_DELAY_TIME = 0.5f;
54const S32 TAB_PADDING = 15; 55const S32 TAB_PADDING = 15;
55const S32 TABCNTR_TAB_MIN_WIDTH = 60; 56const S32 TABCNTR_TAB_MIN_WIDTH = 60;
56const S32 TABCNTR_TAB_MAX_WIDTH = 150; 57const S32 TABCNTR_TAB_MAX_WIDTH = 150;
@@ -81,6 +82,7 @@ LLTabContainerCommon::LLTabContainerCommon(
81 mLockedTabCount(0) 82 mLockedTabCount(0)
82{ 83{
83 setMouseOpaque(FALSE); 84 setMouseOpaque(FALSE);
85 mDragAndDropDelayTimer.stop();
84} 86}
85 87
86 88
@@ -101,9 +103,11 @@ LLTabContainerCommon::LLTabContainerCommon(
101 mCallbackUserdata( callback_userdata ), 103 mCallbackUserdata( callback_userdata ),
102 mTitleBox(NULL), 104 mTitleBox(NULL),
103 mTopBorderHeight(LLPANEL_BORDER_WIDTH), 105 mTopBorderHeight(LLPANEL_BORDER_WIDTH),
104 mTabPosition(pos) 106 mTabPosition(pos),
107 mLockedTabCount(0)
105{ 108{
106 setMouseOpaque(FALSE); 109 setMouseOpaque(FALSE);
110 mDragAndDropDelayTimer.stop();
107} 111}
108 112
109 113
@@ -731,8 +735,8 @@ LLTabContainer::LLTabContainer(
731 : 735 :
732 LLTabContainerCommon(name, rect, pos, close_callback, callback_userdata, bordered), 736 LLTabContainerCommon(name, rect, pos, close_callback, callback_userdata, bordered),
733 mLeftArrowBtn(NULL), 737 mLeftArrowBtn(NULL),
734 mRightArrowBtn(NULL),
735 mJumpLeftArrowBtn(NULL), 738 mJumpLeftArrowBtn(NULL),
739 mRightArrowBtn(NULL),
736 mJumpRightArrowBtn(NULL), 740 mJumpRightArrowBtn(NULL),
737 mRightTabBtnOffset(0), 741 mRightTabBtnOffset(0),
738 mMinTabWidth(TABCNTR_TAB_MIN_WIDTH), 742 mMinTabWidth(TABCNTR_TAB_MIN_WIDTH),
@@ -749,8 +753,8 @@ LLTabContainer::LLTabContainer(
749 : 753 :
750 LLTabContainerCommon(name, rect_control, pos, close_callback, callback_userdata, bordered), 754 LLTabContainerCommon(name, rect_control, pos, close_callback, callback_userdata, bordered),
751 mLeftArrowBtn(NULL), 755 mLeftArrowBtn(NULL),
752 mRightArrowBtn(NULL),
753 mJumpLeftArrowBtn(NULL), 756 mJumpLeftArrowBtn(NULL),
757 mRightArrowBtn(NULL),
754 mJumpRightArrowBtn(NULL), 758 mJumpRightArrowBtn(NULL),
755 mRightTabBtnOffset(0), 759 mRightTabBtnOffset(0),
756 mMinTabWidth(TABCNTR_TAB_MIN_WIDTH), 760 mMinTabWidth(TABCNTR_TAB_MIN_WIDTH),
@@ -1576,43 +1580,48 @@ BOOL LLTabContainer::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, EDrag
1576{ 1580{
1577 BOOL has_scroll_arrows = (mMaxScrollPos > 0); 1581 BOOL has_scroll_arrows = (mMaxScrollPos > 0);
1578 1582
1579 if (has_scroll_arrows) 1583 if( mDragAndDropDelayTimer.getElapsedTimeF32() > SCROLL_DELAY_TIME )
1580 { 1584 {
1581 if (mJumpLeftArrowBtn->getRect().pointInRect(x, y)) 1585
1582 { 1586 if (has_scroll_arrows)
1583 S32 local_x = x - mJumpLeftArrowBtn->getRect().mLeft;
1584 S32 local_y = y - mJumpLeftArrowBtn->getRect().mBottom;
1585 mJumpLeftArrowBtn->handleHover(local_x, local_y, mask);
1586 }
1587 if (mJumpRightArrowBtn->getRect().pointInRect(x, y))
1588 {
1589 S32 local_x = x - mJumpRightArrowBtn->getRect().mLeft;
1590 S32 local_y = y - mJumpRightArrowBtn->getRect().mBottom;
1591 mJumpRightArrowBtn->handleHover(local_x, local_y, mask);
1592 }
1593 if (mLeftArrowBtn->getRect().pointInRect(x, y))
1594 {
1595 S32 local_x = x - mLeftArrowBtn->getRect().mLeft;
1596 S32 local_y = y - mLeftArrowBtn->getRect().mBottom;
1597 mLeftArrowBtn->handleHover(local_x, local_y, mask);
1598 }
1599 else if (mRightArrowBtn->getRect().pointInRect(x, y))
1600 { 1587 {
1601 S32 local_x = x - mRightArrowBtn->getRect().mLeft; 1588 if (mJumpLeftArrowBtn->getRect().pointInRect(x, y))
1602 S32 local_y = y - mRightArrowBtn->getRect().mBottom; 1589 {
1603 mRightArrowBtn->handleHover(local_x, local_y, mask); 1590 S32 local_x = x - mJumpLeftArrowBtn->getRect().mLeft;
1591 S32 local_y = y - mJumpLeftArrowBtn->getRect().mBottom;
1592 mJumpLeftArrowBtn->handleHover(local_x, local_y, mask);
1593 }
1594 if (mJumpRightArrowBtn->getRect().pointInRect(x, y))
1595 {
1596 S32 local_x = x - mJumpRightArrowBtn->getRect().mLeft;
1597 S32 local_y = y - mJumpRightArrowBtn->getRect().mBottom;
1598 mJumpRightArrowBtn->handleHover(local_x, local_y, mask);
1599 }
1600 if (mLeftArrowBtn->getRect().pointInRect(x, y))
1601 {
1602 S32 local_x = x - mLeftArrowBtn->getRect().mLeft;
1603 S32 local_y = y - mLeftArrowBtn->getRect().mBottom;
1604 mLeftArrowBtn->handleHover(local_x, local_y, mask);
1605 }
1606 else if (mRightArrowBtn->getRect().pointInRect(x, y))
1607 {
1608 S32 local_x = x - mRightArrowBtn->getRect().mLeft;
1609 S32 local_y = y - mRightArrowBtn->getRect().mBottom;
1610 mRightArrowBtn->handleHover(local_x, local_y, mask);
1611 }
1604 } 1612 }
1605 }
1606 1613
1607 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter) 1614 for(tuple_list_t::iterator iter = mTabList.begin(); iter != mTabList.end(); ++iter)
1608 {
1609 LLTabTuple* tuple = *iter;
1610 tuple->mButton->setVisible( TRUE );
1611 S32 local_x = x - tuple->mButton->getRect().mLeft;
1612 S32 local_y = y - tuple->mButton->getRect().mBottom;
1613 if (tuple->mButton->pointInView(local_x, local_y) && tuple->mButton->getEnabled() && !tuple->mTabPanel->getVisible())
1614 { 1615 {
1615 tuple->mButton->onCommit(); 1616 LLTabTuple* tuple = *iter;
1617 tuple->mButton->setVisible( TRUE );
1618 S32 local_x = x - tuple->mButton->getRect().mLeft;
1619 S32 local_y = y - tuple->mButton->getRect().mBottom;
1620 if (tuple->mButton->pointInView(local_x, local_y) && tuple->mButton->getEnabled() && !tuple->mTabPanel->getVisible())
1621 {
1622 tuple->mButton->onCommit();
1623 mDragAndDropDelayTimer.stop();
1624 }
1616 } 1625 }
1617 } 1626 }
1618 1627
@@ -1641,4 +1650,4 @@ void LLTabContainer::setTabImage(LLPanel* child, std::string image_name)
1641 // tabs have changed size, might need to scroll to see current tab 1650 // tabs have changed size, might need to scroll to see current tab
1642 updateMaxScrollPos(); 1651 updateMaxScrollPos();
1643 } 1652 }
1644} \ No newline at end of file 1653}
diff --git a/linden/indra/llui/lltabcontainer.h b/linden/indra/llui/lltabcontainer.h
index 7d501d2..f3365c3 100644
--- a/linden/indra/llui/lltabcontainer.h
+++ b/linden/indra/llui/lltabcontainer.h
@@ -117,7 +117,9 @@ public:
117 virtual void setTabImage(LLPanel* child, std::string img_name); 117 virtual void setTabImage(LLPanel* child, std::string img_name);
118 void setTitle( const LLString& title ); 118 void setTitle( const LLString& title );
119 const LLString getPanelTitle(S32 index); 119 const LLString getPanelTitle(S32 index);
120 120
121 void setDragAndDropDelayTimer() { mDragAndDropDelayTimer.start(); }
122
121 virtual void setTopBorderHeight(S32 height); 123 virtual void setTopBorderHeight(S32 height);
122 124
123 virtual void setTabChangeCallback(LLPanel* tab, void (*on_tab_clicked)(void*,bool)); 125 virtual void setTabChangeCallback(LLPanel* tab, void (*on_tab_clicked)(void*,bool));
@@ -175,6 +177,8 @@ protected:
175 S32 mScrollPosPixels; 177 S32 mScrollPosPixels;
176 S32 mMaxScrollPos; 178 S32 mMaxScrollPos;
177 179
180 LLFrameTimer mDragAndDropDelayTimer;
181
178 void (*mCloseCallback)(void*); 182 void (*mCloseCallback)(void*);
179 void* mCallbackUserdata; 183 void* mCallbackUserdata;
180 184
diff --git a/linden/indra/llui/lltexteditor.cpp b/linden/indra/llui/lltexteditor.cpp
index 80205d3..513670b 100644
--- a/linden/indra/llui/lltexteditor.cpp
+++ b/linden/indra/llui/lltexteditor.cpp
@@ -46,6 +46,7 @@
46#include "llclipboard.h" 46#include "llclipboard.h"
47#include "llscrollbar.h" 47#include "llscrollbar.h"
48#include "llstl.h" 48#include "llstl.h"
49#include "llstring.h"
49#include "llkeyboard.h" 50#include "llkeyboard.h"
50#include "llkeywords.h" 51#include "llkeywords.h"
51#include "llundo.h" 52#include "llundo.h"
@@ -514,8 +515,10 @@ void LLTextEditor::truncate()
514 515
515void LLTextEditor::setText(const LLString &utf8str) 516void LLTextEditor::setText(const LLString &utf8str)
516{ 517{
517 mUTF8Text = utf8str; 518 // LLString::removeCRLF(utf8str);
518 mWText = utf8str_to_wstring(utf8str); 519 mUTF8Text = utf8str_removeCRLF(utf8str);
520 // mUTF8Text = utf8str;
521 mWText = utf8str_to_wstring(mUTF8Text);
519 mTextIsUpToDate = TRUE; 522 mTextIsUpToDate = TRUE;
520 523
521 truncate(); 524 truncate();
@@ -2491,6 +2494,8 @@ void LLTextEditor::redo()
2491// virtual, from LLView 2494// virtual, from LLView
2492void LLTextEditor::onFocusLost() 2495void LLTextEditor::onFocusLost()
2493{ 2496{
2497 getWindow()->allowLanguageTextInput(FALSE);
2498
2494 // Route menu back to the default 2499 // Route menu back to the default
2495 if( gEditMenuHandler == this ) 2500 if( gEditMenuHandler == this )
2496 { 2501 {
@@ -3057,6 +3062,12 @@ void LLTextEditor::setFocus( BOOL new_state )
3057 // Don't change anything if the focus state didn't change 3062 // Don't change anything if the focus state didn't change
3058 if (new_state == old_state) return; 3063 if (new_state == old_state) return;
3059 3064
3065 // Notify early if we are loosing focus.
3066 if (!new_state)
3067 {
3068 getWindow()->allowLanguageTextInput(FALSE);
3069 }
3070
3060 LLUICtrl::setFocus( new_state ); 3071 LLUICtrl::setFocus( new_state );
3061 3072
3062 if( new_state ) 3073 if( new_state )
@@ -3077,6 +3088,12 @@ void LLTextEditor::setFocus( BOOL new_state )
3077 3088
3078 endSelection(); 3089 endSelection();
3079 } 3090 }
3091
3092 // Notify late if we are gaining focus.
3093 if (new_state && !mReadOnly)
3094 {
3095 getWindow()->allowLanguageTextInput(TRUE);
3096 }
3080} 3097}
3081 3098
3082BOOL LLTextEditor::acceptsTextInput() const 3099BOOL LLTextEditor::acceptsTextInput() const
diff --git a/linden/indra/llui/llviewquery.cpp b/linden/indra/llui/llviewquery.cpp
index 3f9ccf4..65f191b 100644
--- a/linden/indra/llui/llviewquery.cpp
+++ b/linden/indra/llui/llviewquery.cpp
@@ -26,6 +26,8 @@
26 * COMPLETENESS OR PERFORMANCE. 26 * COMPLETENESS OR PERFORMANCE.
27 */ 27 */
28 28
29#include "linden_common.h"
30
29#include "llview.h" 31#include "llview.h"
30#include "lluictrl.h" 32#include "lluictrl.h"
31#include "llviewquery.h" 33#include "llviewquery.h"