/***************************************************************************
* Copyright (C) 2006-2010 by Peter Penz <peter.penz19@gmail.com> *
* Copyright (C) 2006 by Gregor Kališnik <gregor@podnapisi.net> *
+ * Copyright (C) 2012 by Stuart Citrin <ctrn3e8@gmail.com> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
#ifndef FILTERBAR_H
#define FILTERBAR_H
-#include <QtGui/QWidget>
+#include <QWidget>
-class KLineEdit;
+class QLineEdit;
+class QToolButton;
/**
* @brief Provides an input field for filtering the currently shown items.
Q_OBJECT
public:
- FilterBar(QWidget* parent = 0);
- virtual ~FilterBar();
+ explicit FilterBar(QWidget* parent = nullptr);
+ ~FilterBar() override;
+
+ /** Called by view container to hide this **/
+ void closeFilterBar();
/**
* Selects the whole text of the filter bar.
public slots:
/** Clears the input field. */
void clear();
+ /** Clears the input field if the "lock button" is disabled. */
+ void slotUrlChanged();
+ /** The input field is cleared also if the "lock button" is released. */
+ void slotToggleLockButton(bool checked);
signals:
/**
*/
void closeRequest();
+ /*
+ * Emitted as soon as the focus should be returned back to the view.
+ */
+ void focusViewRequest();
+
protected:
- virtual void showEvent(QShowEvent* event);
- virtual void keyReleaseEvent(QKeyEvent* event);
+ void showEvent(QShowEvent* event) override;
+ void keyReleaseEvent(QKeyEvent* event) override;
private:
- KLineEdit* m_filterInput;
+ QLineEdit* m_filterInput;
+ QToolButton* m_lockButton;
};
#endif