summaryrefslogtreecommitdiff
path: root/indra/llui/llscrolllistcolumn.h
diff options
context:
space:
mode:
Diffstat (limited to 'indra/llui/llscrolllistcolumn.h')
-rw-r--r--indra/llui/llscrolllistcolumn.h344
1 files changed, 172 insertions, 172 deletions
diff --git a/indra/llui/llscrolllistcolumn.h b/indra/llui/llscrolllistcolumn.h
index 042e9e5f02..72dfcdafe0 100644
--- a/indra/llui/llscrolllistcolumn.h
+++ b/indra/llui/llscrolllistcolumn.h
@@ -1,172 +1,172 @@
-/**
- * @file llscrollcolumnheader.h
- * @brief Scroll lists are composed of rows (items), each of which
- * contains columns (cells).
- *
- * $LicenseInfo:firstyear=2007&license=viewerlgpl$
- * Second Life Viewer Source Code
- * Copyright (C) 2010, Linden Research, Inc.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation;
- * version 2.1 of the License only.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
- * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
- * $/LicenseInfo$
- */
-
-#ifndef LLSCROLLLISTCOLUMN_H
-#define LLSCROLLLISTCOLUMN_H
-
-#include "llrect.h"
-#include "lluistring.h"
-#include "llbutton.h"
-#include "llinitparam.h"
-
-class LLScrollListColumn;
-class LLResizeBar;
-class LLScrollListCtrl;
-
-class LLScrollColumnHeader : public LLButton
-{
-public:
- struct Params : public LLInitParam::Block<Params, LLButton::Params>
- {
- Mandatory<LLScrollListColumn*> column;
-
- Params();
- };
- LLScrollColumnHeader(const Params&);
- ~LLScrollColumnHeader();
-
- /*virtual*/ void draw();
- /*virtual*/ bool handleDoubleClick(S32 x, S32 y, MASK mask);
-
- /*virtual*/ LLView* findSnapEdge(S32& new_edge_val, const LLCoordGL& mouse_dir, ESnapEdge snap_edge, ESnapType snap_type, S32 threshold, S32 padding);
- /*virtual*/ void handleReshape(const LLRect& new_rect, bool by_user = false);
-
- LLScrollListColumn* getColumn() { return mColumn; }
- void setHasResizableElement(bool resizable);
- void updateResizeBars();
- bool canResize();
- void enableResizeBar(bool enable);
-
- void onClick(const LLSD& data);
-
-private:
- LLScrollListColumn* mColumn;
- LLResizeBar* mResizeBar;
- bool mHasResizableElement;
-};
-
-/*
- * A simple data class describing a column within a scroll list.
- */
-class LLScrollListColumn
-{
-public:
- typedef enum e_sort_direction
- {
- DESCENDING,
- ASCENDING
- } ESortDirection;
-
- struct SortNames
- : public LLInitParam::TypeValuesHelper<LLScrollListColumn::ESortDirection, SortNames>
- {
- static void declareValues();
- };
-
- struct Params : public LLInitParam::Block<Params>
- {
- Optional<std::string> name,
- tool_tip;
- Optional<std::string> sort_column;
- Optional<ESortDirection, SortNames> sort_direction;
- Optional<bool> sort_ascending;
-
- struct Width : public LLInitParam::ChoiceBlock<Width>
- {
- Alternative<bool> dynamic_width;
- Alternative<S32> pixel_width;
- Alternative<F32> relative_width;
-
- Width()
- : dynamic_width("dynamic_width", false),
- pixel_width("width"),
- relative_width("relative_width", -1.f)
- {
- addSynonym(relative_width, "relwidth");
- }
- };
- Optional<Width> width;
-
- // either an image or label is used in column header
- struct Header : public LLInitParam::ChoiceBlock<Header>
- {
- Alternative<std::string> label;
- Alternative<LLUIImage*> image;
-
- Header()
- : label("label"),
- image("image")
- {}
- };
- Optional<Header> header;
-
- Optional<LLFontGL::HAlign> halign;
-
- Params()
- : name("name"),
- tool_tip("tool_tip"),
- sort_column("sort_column"),
- sort_direction("sort_direction"),
- sort_ascending("sort_ascending", true),
- halign("halign", LLFontGL::LEFT)
- {
- // default choice to "dynamic_width"
- changeDefault(width.dynamic_width, true);
-
- addSynonym(sort_column, "sort");
- }
- };
-
- static const Params& getDefaultParams();
-
- //NOTE: this is default constructible so we can store it in a map.
- LLScrollListColumn(const Params& p = getDefaultParams(), LLScrollListCtrl* = NULL);
-
- void setWidth(S32 width);
- S32 getWidth() const { return mWidth; }
-
-public:
- // Public data is fine so long as this remains a simple struct-like data class.
- // If it ever gets any smarter than that, these should all become private
- // with protected or public accessor methods added as needed. -MG
- std::string mName;
- std::string mSortingColumn;
- ESortDirection mSortDirection;
- LLUIString mLabel;
- F32 mRelWidth;
- bool mDynamicWidth;
- S32 mMaxContentWidth;
- S32 mIndex;
- LLScrollListCtrl* mParentCtrl;
- LLScrollColumnHeader* mHeader;
- LLFontGL::HAlign mFontAlignment;
-
-private:
- S32 mWidth;
-};
-
-#endif
+/**
+ * @file llscrollcolumnheader.h
+ * @brief Scroll lists are composed of rows (items), each of which
+ * contains columns (cells).
+ *
+ * $LicenseInfo:firstyear=2007&license=viewerlgpl$
+ * Second Life Viewer Source Code
+ * Copyright (C) 2010, Linden Research, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation;
+ * version 2.1 of the License only.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
+ * $/LicenseInfo$
+ */
+
+#ifndef LLSCROLLLISTCOLUMN_H
+#define LLSCROLLLISTCOLUMN_H
+
+#include "llrect.h"
+#include "lluistring.h"
+#include "llbutton.h"
+#include "llinitparam.h"
+
+class LLScrollListColumn;
+class LLResizeBar;
+class LLScrollListCtrl;
+
+class LLScrollColumnHeader : public LLButton
+{
+public:
+ struct Params : public LLInitParam::Block<Params, LLButton::Params>
+ {
+ Mandatory<LLScrollListColumn*> column;
+
+ Params();
+ };
+ LLScrollColumnHeader(const Params&);
+ ~LLScrollColumnHeader();
+
+ /*virtual*/ void draw();
+ /*virtual*/ bool handleDoubleClick(S32 x, S32 y, MASK mask);
+
+ /*virtual*/ LLView* findSnapEdge(S32& new_edge_val, const LLCoordGL& mouse_dir, ESnapEdge snap_edge, ESnapType snap_type, S32 threshold, S32 padding);
+ /*virtual*/ void handleReshape(const LLRect& new_rect, bool by_user = false);
+
+ LLScrollListColumn* getColumn() { return mColumn; }
+ void setHasResizableElement(bool resizable);
+ void updateResizeBars();
+ bool canResize();
+ void enableResizeBar(bool enable);
+
+ void onClick(const LLSD& data);
+
+private:
+ LLScrollListColumn* mColumn;
+ LLResizeBar* mResizeBar;
+ bool mHasResizableElement;
+};
+
+/*
+ * A simple data class describing a column within a scroll list.
+ */
+class LLScrollListColumn
+{
+public:
+ typedef enum e_sort_direction
+ {
+ DESCENDING,
+ ASCENDING
+ } ESortDirection;
+
+ struct SortNames
+ : public LLInitParam::TypeValuesHelper<LLScrollListColumn::ESortDirection, SortNames>
+ {
+ static void declareValues();
+ };
+
+ struct Params : public LLInitParam::Block<Params>
+ {
+ Optional<std::string> name,
+ tool_tip;
+ Optional<std::string> sort_column;
+ Optional<ESortDirection, SortNames> sort_direction;
+ Optional<bool> sort_ascending;
+
+ struct Width : public LLInitParam::ChoiceBlock<Width>
+ {
+ Alternative<bool> dynamic_width;
+ Alternative<S32> pixel_width;
+ Alternative<F32> relative_width;
+
+ Width()
+ : dynamic_width("dynamic_width", false),
+ pixel_width("width"),
+ relative_width("relative_width", -1.f)
+ {
+ addSynonym(relative_width, "relwidth");
+ }
+ };
+ Optional<Width> width;
+
+ // either an image or label is used in column header
+ struct Header : public LLInitParam::ChoiceBlock<Header>
+ {
+ Alternative<std::string> label;
+ Alternative<LLUIImage*> image;
+
+ Header()
+ : label("label"),
+ image("image")
+ {}
+ };
+ Optional<Header> header;
+
+ Optional<LLFontGL::HAlign> halign;
+
+ Params()
+ : name("name"),
+ tool_tip("tool_tip"),
+ sort_column("sort_column"),
+ sort_direction("sort_direction"),
+ sort_ascending("sort_ascending", true),
+ halign("halign", LLFontGL::LEFT)
+ {
+ // default choice to "dynamic_width"
+ changeDefault(width.dynamic_width, true);
+
+ addSynonym(sort_column, "sort");
+ }
+ };
+
+ static const Params& getDefaultParams();
+
+ //NOTE: this is default constructible so we can store it in a map.
+ LLScrollListColumn(const Params& p = getDefaultParams(), LLScrollListCtrl* = NULL);
+
+ void setWidth(S32 width);
+ S32 getWidth() const { return mWidth; }
+
+public:
+ // Public data is fine so long as this remains a simple struct-like data class.
+ // If it ever gets any smarter than that, these should all become private
+ // with protected or public accessor methods added as needed. -MG
+ std::string mName;
+ std::string mSortingColumn;
+ ESortDirection mSortDirection;
+ LLUIString mLabel;
+ F32 mRelWidth;
+ bool mDynamicWidth;
+ S32 mMaxContentWidth;
+ S32 mIndex;
+ LLScrollListCtrl* mParentCtrl;
+ LLScrollColumnHeader* mHeader;
+ LLFontGL::HAlign mFontAlignment;
+
+private:
+ S32 mWidth;
+};
+
+#endif