forked from qt-creator/qt-creator
Change-Id: I4e6706f284182226da8c9815394f36e9764feab2 Reviewed-by: Eike Ziller <eike.ziller@qt.io>
176 lines
5.2 KiB
C++
176 lines
5.2 KiB
C++
/****************************************************************************
|
|
**
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
** Contact: https://www.qt.io/licensing/
|
|
**
|
|
** This file is part of Qt Creator.
|
|
**
|
|
** Commercial License Usage
|
|
** Licensees holding valid commercial Qt licenses may use this file in
|
|
** accordance with the commercial license agreement provided with the
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
|
**
|
|
** GNU General Public License Usage
|
|
** Alternatively, this file may be used under the terms of the GNU
|
|
** General Public License version 3 as published by the Free Software
|
|
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
|
|
** included in the packaging of this file. Please review the following
|
|
** information to ensure the GNU General Public License requirements will
|
|
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
|
**
|
|
****************************************************************************/
|
|
|
|
#pragma once
|
|
|
|
#include "utils_global.h"
|
|
#include "completinglineedit.h"
|
|
|
|
#include <QAbstractButton>
|
|
|
|
#include <functional>
|
|
|
|
QT_BEGIN_NAMESPACE
|
|
class QEvent;
|
|
class QKeySequence;
|
|
QT_END_NAMESPACE
|
|
|
|
namespace Utils {
|
|
|
|
class FancyLineEditPrivate;
|
|
|
|
class QTCREATOR_UTILS_EXPORT IconButton: public QAbstractButton
|
|
{
|
|
Q_OBJECT
|
|
Q_PROPERTY(float iconOpacity READ iconOpacity WRITE setIconOpacity)
|
|
Q_PROPERTY(bool autoHide READ hasAutoHide WRITE setAutoHide)
|
|
public:
|
|
explicit IconButton(QWidget *parent = nullptr);
|
|
void paintEvent(QPaintEvent *event) override;
|
|
float iconOpacity() { return m_iconOpacity; }
|
|
void setIconOpacity(float value) { m_iconOpacity = value; update(); }
|
|
void animateShow(bool visible);
|
|
|
|
void setAutoHide(bool hide) { m_autoHide = hide; }
|
|
bool hasAutoHide() const { return m_autoHide; }
|
|
|
|
QSize sizeHint() const override;
|
|
|
|
protected:
|
|
void keyPressEvent(QKeyEvent *ke) override;
|
|
void keyReleaseEvent(QKeyEvent *ke) override;
|
|
|
|
private:
|
|
float m_iconOpacity;
|
|
bool m_autoHide;
|
|
QIcon m_icon;
|
|
};
|
|
|
|
class QTCREATOR_UTILS_EXPORT FancyLineEdit : public CompletingLineEdit
|
|
{
|
|
Q_OBJECT
|
|
Q_ENUMS(Side)
|
|
|
|
public:
|
|
enum Side {Left = 0, Right = 1};
|
|
|
|
explicit FancyLineEdit(QWidget *parent = nullptr);
|
|
~FancyLineEdit() override;
|
|
|
|
void setTextKeepingActiveCursor(const QString &text);
|
|
|
|
QIcon buttonIcon(Side side) const;
|
|
void setButtonIcon(Side side, const QIcon &icon);
|
|
|
|
QMenu *buttonMenu(Side side) const;
|
|
void setButtonMenu(Side side, QMenu *menu);
|
|
|
|
void setButtonVisible(Side side, bool visible);
|
|
bool isButtonVisible(Side side) const;
|
|
QAbstractButton *button(Side side) const;
|
|
|
|
void setButtonToolTip(Side side, const QString &);
|
|
void setButtonFocusPolicy(Side side, Qt::FocusPolicy policy);
|
|
|
|
// Set whether tabbing in will trigger the menu.
|
|
void setMenuTabFocusTrigger(Side side, bool v);
|
|
bool hasMenuTabFocusTrigger(Side side) const;
|
|
|
|
// Set if icon should be hidden when text is empty
|
|
void setAutoHideButton(Side side, bool h);
|
|
bool hasAutoHideButton(Side side) const;
|
|
|
|
|
|
// Completion
|
|
|
|
// Enable a history completer with a history of entries.
|
|
void setHistoryCompleter(const QString &historyKey, bool restoreLastItemFromHistory = false);
|
|
// Sets a completer that is not a history completer.
|
|
void setSpecialCompleter(QCompleter *completer);
|
|
|
|
|
|
// Filtering
|
|
|
|
// Enables filtering
|
|
void setFiltering(bool on);
|
|
|
|
|
|
// Validation
|
|
|
|
// line edit, (out)errorMessage -> valid?
|
|
using ValidationFunction = std::function<bool(FancyLineEdit *, QString *)>;
|
|
enum State { Invalid, DisplayingPlaceholderText, Valid };
|
|
|
|
State state() const;
|
|
bool isValid() const;
|
|
QString errorMessage() const;
|
|
|
|
void setValidationFunction(const ValidationFunction &fn);
|
|
static ValidationFunction defaultValidationFunction();
|
|
void validate();
|
|
void onEditingFinished();
|
|
|
|
static void setCamelCaseNavigationEnabled(bool enabled);
|
|
static void setCompletionShortcut(const QKeySequence &shortcut);
|
|
|
|
protected:
|
|
// Custom behaviour can be added here.
|
|
virtual void handleChanged(const QString &) {}
|
|
void keyPressEvent(QKeyEvent *event) override;
|
|
|
|
signals:
|
|
void buttonClicked(Utils::FancyLineEdit::Side side);
|
|
void leftButtonClicked();
|
|
void rightButtonClicked();
|
|
|
|
void filterChanged(const QString &);
|
|
|
|
void validChanged(bool validState);
|
|
void validReturnPressed();
|
|
|
|
protected:
|
|
void resizeEvent(QResizeEvent *e) override;
|
|
|
|
virtual QString fixInputString(const QString &string);
|
|
|
|
private:
|
|
void iconClicked();
|
|
|
|
static bool validateWithValidator(FancyLineEdit *edit, QString *errorMessage);
|
|
// Unimplemented, to force the user to make a decision on
|
|
// whether to use setHistoryCompleter() or setSpecialCompleter().
|
|
void setCompleter(QCompleter *);
|
|
|
|
void updateMargins();
|
|
void updateButtonPositions();
|
|
bool camelCaseBackward(bool mark);
|
|
bool camelCaseForward(bool mark);
|
|
friend class FancyLineEditPrivate;
|
|
|
|
FancyLineEditPrivate *d;
|
|
};
|
|
|
|
} // namespace Utils
|