mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Desktop: set filter negation texts
The texts may not be perfect, but this is a start. Replace the buttons by combo-boxes. This will allow potential extension to "any of". Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
de569b03bb
commit
11b357a4f0
2 changed files with 66 additions and 44 deletions
|
@ -20,7 +20,7 @@ FilterWidget2::FilterWidget2(QWidget* parent) : QWidget(parent), ignoreSignal(fa
|
|||
|
||||
// TODO: unhide this when we discover how to search for equipment.
|
||||
ui.equipment->hide();
|
||||
ui.equipmentNegate->hide();
|
||||
ui.equipmentMode->hide();
|
||||
ui.labelEquipment->hide();
|
||||
|
||||
ui.fromDate->setDisplayFormat(prefs.date_format);
|
||||
|
@ -50,6 +50,11 @@ FilterWidget2::FilterWidget2(QWidget* parent) : QWidget(parent), ignoreSignal(fa
|
|||
connect(ui.minVisibility, &StarWidget::valueChanged,
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
// We need these insane casts because Qt decided to function-overload some of their signals(!).
|
||||
// QDoubleSpinBox::valueChanged() sends double and QString using the same signal name.
|
||||
// QComboBox::currentIndexChanged() sends int and QString using the same signal name.
|
||||
// Qt 5.7 provides a "convenient" helper that hides this, but only if compiling in C++14
|
||||
// or higher. One can then write: "QOverload<double>(&QDoubleSpinBox::valueChanged)", etc.
|
||||
connect(ui.maxAirTemp, static_cast<void (QDoubleSpinBox::*)(double)>(&QDoubleSpinBox::valueChanged),
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
|
@ -77,19 +82,19 @@ FilterWidget2::FilterWidget2(QWidget* parent) : QWidget(parent), ignoreSignal(fa
|
|||
connect(ui.tags, &QLineEdit::textChanged,
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.tagsNegate, &QToolButton::toggled,
|
||||
connect(ui.tagsMode, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.people, &QLineEdit::textChanged,
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.peopleNegate, &QToolButton::toggled,
|
||||
connect(ui.peopleMode, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.location, &QLineEdit::textChanged,
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.locationNegate, &QToolButton::toggled,
|
||||
connect(ui.locationMode, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged),
|
||||
this, &FilterWidget2::updateFilter);
|
||||
|
||||
connect(ui.logged, &QCheckBox::stateChanged,
|
||||
|
@ -135,10 +140,11 @@ void FilterWidget2::clearFilter()
|
|||
ui.fromTime->setTime(filterData.fromTime);
|
||||
ui.toDate->setDate(filterData.toDate.date());
|
||||
ui.toTime->setTime(filterData.toTime);
|
||||
ui.tagsNegate->setChecked(filterData.tagsNegate);
|
||||
ui.peopleNegate->setChecked(filterData.peopleNegate);
|
||||
ui.locationNegate->setChecked(filterData.locationNegate);
|
||||
ui.equipmentNegate->setChecked(filterData.equipmentNegate);
|
||||
ui.tagsMode->setCurrentIndex(filterData.tagsNegate ? 1 : 0);
|
||||
ui.peopleMode->setCurrentIndex(filterData.peopleNegate ? 1 : 0);
|
||||
ui.locationMode->setCurrentIndex(filterData.locationNegate ? 1 : 0);
|
||||
ui.equipmentMode->setCurrentIndex(filterData.equipmentNegate ? 1 : 0);
|
||||
|
||||
ignoreSignal = false;
|
||||
|
||||
filterDataChanged(filterData);
|
||||
|
@ -180,10 +186,10 @@ void FilterWidget2::updateFilter()
|
|||
filterData.people = ui.people->text().split(",", QString::SkipEmptyParts);
|
||||
filterData.location = ui.location->text().split(",", QString::SkipEmptyParts);
|
||||
filterData.equipment = ui.equipment->text().split(",", QString::SkipEmptyParts);
|
||||
filterData.tagsNegate = ui.tagsNegate->isChecked();
|
||||
filterData.peopleNegate = ui.peopleNegate->isChecked();
|
||||
filterData.locationNegate = ui.locationNegate->isChecked();
|
||||
filterData.equipmentNegate = ui.equipmentNegate->isChecked();
|
||||
filterData.tagsNegate = ui.tagsMode->currentIndex() == 1;
|
||||
filterData.peopleNegate = ui.peopleMode->currentIndex() == 1;
|
||||
filterData.locationNegate = ui.locationMode->currentIndex() == 1;
|
||||
filterData.equipmentNegate = ui.equipmentMode->currentIndex() == 1;
|
||||
filterData.logged = ui.logged->isChecked();
|
||||
filterData.planned = ui.planned->isChecked();
|
||||
|
||||
|
|
|
@ -291,44 +291,60 @@
|
|||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="8" column="2" colspan="2">
|
||||
<widget class="QToolButton" name="tagsNegate">
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Click to negate</string>
|
||||
</property>
|
||||
<item row="8" column="2">
|
||||
<widget class="QComboBox" name="tagsMode">
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>All of</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>None of</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="9" column="2" colspan="2">
|
||||
<widget class="QToolButton" name="peopleNegate">
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Click to negate</string>
|
||||
</property>
|
||||
<item row="9" column="2">
|
||||
<widget class="QComboBox" name="peopleMode">
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>All of</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>None of</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="10" column="2" colspan="2">
|
||||
<widget class="QToolButton" name="locationNegate">
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Click to negate</string>
|
||||
</property>
|
||||
<item row="10" column="2">
|
||||
<widget class="QComboBox" name="locationMode">
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Matches</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Doesn't match</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="11" column="2" colspan="2">
|
||||
<widget class="QToolButton" name="equipmentNegate">
|
||||
<property name="checkable">
|
||||
<bool>true</bool>
|
||||
</property>
|
||||
<property name="toolTip">
|
||||
<string>Click to negate</string>
|
||||
</property>
|
||||
<item row="11" column="2">
|
||||
<widget class="QComboBox" name="equipmentMode">
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>All of</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>None of</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="12" column="0">
|
||||
|
|
Loading…
Add table
Reference in a new issue