1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
#include "./clearcombobox.h"
#include <QHBoxLayout>
#include <QStyle>
#include <QStyleOptionComboBox>
namespace QtUtilities {
/*!
* \class ClearComboBox
* \brief A QComboBox with an embedded button for clearing its contents.
*/
/// \cond
static inline auto *getComboBoxLineEdit(QComboBox *comboBox)
{
comboBox->setEditable(true);
return comboBox->lineEdit();
}
/// \endcond
/*!
* \brief Constructs a clear combo box.
* \remarks The combo box is initialized to be editable and which must not be changed.
*/
ClearComboBox::ClearComboBox(QWidget *parent)
: QComboBox(parent)
, ButtonOverlay(this, getComboBoxLineEdit(this))
{
ButtonOverlay::setClearButtonEnabled(true);
}
/*!
* \brief Destroys the clear combo box.
*/
ClearComboBox::~ClearComboBox()
{
}
/*!
* \brief Updates the visibility of the clear button.
*/
void ClearComboBox::handleTextChanged(const QString &text)
{
updateClearButtonVisibility(!text.isEmpty());
}
void ClearComboBox::handleClearButtonClicked()
{
clearEditText();
}
void ClearComboBox::handleCustomLayoutCreated()
{
const QStyle *const s = style();
QStyleOptionComboBox opt;
opt.initFrom(this);
setContentsMarginsFromEditFieldRectAndFrameWidth(
s->subControlRect(QStyle::CC_ComboBox, &opt, QStyle::SC_ComboBoxEditField, this), s->pixelMetric(QStyle::PM_ComboBoxFrameWidth, &opt, this));
connect(this, &ClearComboBox::currentTextChanged, this, &ClearComboBox::handleTextChanged);
}
bool ClearComboBox::isCleared() const
{
return currentText().isEmpty();
}
} // namespace QtUtilities
|