// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef UI_VIEWS_CONTROLS_TABLE_TABLE_HEADER_H_
#define UI_VIEWS_CONTROLS_TABLE_TABLE_HEADER_H_
#include "ui/gfx/font_list.h"
#include "ui/views/view.h"
#include "ui/views/views_export.h"
namespace views {
class TableView;
// Views used to render the header for the table.
class VIEWS_EXPORT TableHeader : public views::View {
public:
// Amount the text is padded on the left/right side.
static const int kHorizontalPadding;
// Amount of space reserved for the indicator and padding.
static const int kSortIndicatorWidth;
explicit TableHeader(TableView* table);
virtual ~TableHeader();
const gfx::FontList& font_list() const { return font_list_; }
// views::View overrides.
virtual void Layout() OVERRIDE;
virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE;
virtual gfx::Size GetPreferredSize() const OVERRIDE;
virtual gfx::NativeCursor GetCursor(const ui::MouseEvent& event) OVERRIDE;
virtual bool OnMousePressed(const ui::MouseEvent& event) OVERRIDE;
virtual bool OnMouseDragged(const ui::MouseEvent& event) OVERRIDE;
virtual void OnMouseReleased(const ui::MouseEvent& event) OVERRIDE;
virtual void OnMouseCaptureLost() OVERRIDE;
virtual void OnGestureEvent(ui::GestureEvent* event) OVERRIDE;
private:
// Used to track the column being resized.
struct ColumnResizeDetails {
ColumnResizeDetails() : column_index(0), initial_x(0), initial_width(0) {}
// Index into table_->visible_columns() that is being resized.
int column_index;
// X-coordinate of the mouse at the time the resize started.
int initial_x;
// Width of the column when the drag started.
int initial_width;
};
// If not already resizing and |event| is over a resizable column starts
// resizing.
bool StartResize(const ui::LocatedEvent& event);
// Continues a resize operation. Does nothing if not in the process of
// resizing.
void ContinueResize(const ui::LocatedEvent& event);
// Toggles the sort order of the column at the location in |event|.
void ToggleSortOrder(const ui::LocatedEvent& event);
// Returns the column to resize given the specified x-coordinate, or -1 if |x|
// is not in the resize range of any columns.
int GetResizeColumn(int x) const;
bool is_resizing() const { return resize_details_.get() != NULL; }
const gfx::FontList font_list_;
TableView* table_;
// If non-null a resize is in progress.
scoped_ptr<ColumnResizeDetails> resize_details_;
DISALLOW_COPY_AND_ASSIGN(TableHeader);
};
} // namespace views
#endif // UI_VIEWS_CONTROLS_TABLE_TABLE_HEADER_H_