mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Move the Suit text box from the Notes tab to the Equipment tab
Sqash latest commit with previous one. Signed-off-by: willemferguson <willemferguson@zoology.up.ac.za>
This commit is contained in:
parent
9a562f221a
commit
78f425de68
6 changed files with 102 additions and 45 deletions
|
@ -4,20 +4,23 @@
|
||||||
#include "desktop-widgets/mainwindow.h" // TODO: Only used temporarilly for edit mode changes
|
#include "desktop-widgets/mainwindow.h" // TODO: Only used temporarilly for edit mode changes
|
||||||
#include "desktop-widgets/simplewidgets.h" // For isGnome3Session()
|
#include "desktop-widgets/simplewidgets.h" // For isGnome3Session()
|
||||||
#include "desktop-widgets/modeldelegates.h"
|
#include "desktop-widgets/modeldelegates.h"
|
||||||
|
#include "desktop-widgets/command.h"
|
||||||
#include "profile-widget/profilewidget2.h"
|
#include "profile-widget/profilewidget2.h"
|
||||||
|
|
||||||
#include "qt-models/cylindermodel.h"
|
#include "qt-models/cylindermodel.h"
|
||||||
#include "qt-models/weightmodel.h"
|
#include "qt-models/weightmodel.h"
|
||||||
|
|
||||||
#include "core/divelist.h"
|
|
||||||
#include "core/subsurface-string.h"
|
#include "core/subsurface-string.h"
|
||||||
|
#include "core/divelist.h"
|
||||||
|
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
|
#include <QCompleter>
|
||||||
|
|
||||||
TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
|
TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
|
||||||
cylindersModel(new CylindersModel(this)),
|
cylindersModel(new CylindersModel(this)),
|
||||||
weightModel(new WeightModel(this))
|
weightModel(new WeightModel(this))
|
||||||
{
|
{
|
||||||
|
QCompleter *suitCompleter;
|
||||||
ui.setupUi(this);
|
ui.setupUi(this);
|
||||||
|
|
||||||
// This makes sure we only delete the models
|
// This makes sure we only delete the models
|
||||||
|
@ -29,6 +32,7 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
|
||||||
ui.cylinders->setModel(cylindersModel);
|
ui.cylinders->setModel(cylindersModel);
|
||||||
ui.weights->setModel(weightModel);
|
ui.weights->setModel(weightModel);
|
||||||
|
|
||||||
|
connect(&diveListNotifier, &DiveListNotifier::divesChanged, this, &TabDiveEquipment::divesChanged);
|
||||||
connect(ui.cylinders->view(), &QTableView::clicked, this, &TabDiveEquipment::editCylinderWidget);
|
connect(ui.cylinders->view(), &QTableView::clicked, this, &TabDiveEquipment::editCylinderWidget);
|
||||||
connect(ui.weights->view(), &QTableView::clicked, this, &TabDiveEquipment::editWeightWidget);
|
connect(ui.weights->view(), &QTableView::clicked, this, &TabDiveEquipment::editWeightWidget);
|
||||||
|
|
||||||
|
@ -53,6 +57,17 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
|
||||||
ui.weights->setBtnToolTip(tr("Add weight system"));
|
ui.weights->setBtnToolTip(tr("Add weight system"));
|
||||||
connect(ui.weights, &TableView::addButtonClicked, this, &TabDiveEquipment::addWeight_clicked);
|
connect(ui.weights, &TableView::addButtonClicked, this, &TabDiveEquipment::addWeight_clicked);
|
||||||
|
|
||||||
|
QAction *action = new QAction(tr("OK"), this);
|
||||||
|
connect(action, &QAction::triggered, this, &TabDiveEquipment::closeWarning);
|
||||||
|
ui.multiDiveWarningMessage->addAction(action);
|
||||||
|
|
||||||
|
action = new QAction(tr("Undo"), this);
|
||||||
|
connect(action, &QAction::triggered, Command::undoAction(this), &QAction::trigger);
|
||||||
|
connect(action, &QAction::triggered, this, &TabDiveEquipment::closeWarning);
|
||||||
|
ui.multiDiveWarningMessage->addAction(action);
|
||||||
|
|
||||||
|
ui.multiDiveWarningMessage->hide();
|
||||||
|
|
||||||
QSettings s;
|
QSettings s;
|
||||||
s.beginGroup("cylinders_dialog");
|
s.beginGroup("cylinders_dialog");
|
||||||
for (int i = 0; i < CylindersModel::COLUMNS; i++) {
|
for (int i = 0; i < CylindersModel::COLUMNS; i++) {
|
||||||
|
@ -67,9 +82,11 @@ TabDiveEquipment::TabDiveEquipment(QWidget *parent) : TabBase(parent),
|
||||||
ui.cylinders->view()->setColumnHidden(i, checked);
|
ui.cylinders->view()->setColumnHidden(i, checked);
|
||||||
ui.cylinders->view()->horizontalHeader()->addAction(action);
|
ui.cylinders->view()->horizontalHeader()->addAction(action);
|
||||||
}
|
}
|
||||||
|
|
||||||
ui.cylinders->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
|
ui.cylinders->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
|
||||||
ui.weights->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
|
ui.weights->view()->horizontalHeader()->setContextMenuPolicy(Qt::ActionsContextMenu);
|
||||||
|
suitCompleter = new QCompleter(&suitModel, ui.suit);
|
||||||
|
suitCompleter->setCaseSensitivity(Qt::CaseInsensitive);
|
||||||
|
ui.suit->setCompleter(suitCompleter);
|
||||||
}
|
}
|
||||||
|
|
||||||
TabDiveEquipment::~TabDiveEquipment()
|
TabDiveEquipment::~TabDiveEquipment()
|
||||||
|
@ -83,6 +100,23 @@ TabDiveEquipment::~TabDiveEquipment()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This function gets called if a field gets updated by an undo command.
|
||||||
|
// Refresh the corresponding UI field.
|
||||||
|
void TabDiveEquipment::divesChanged(const QVector<dive *> &dives, DiveField field)
|
||||||
|
{
|
||||||
|
// If the current dive is not in list of changed dives, do nothing
|
||||||
|
if (!current_dive || !dives.contains(current_dive))
|
||||||
|
return;
|
||||||
|
|
||||||
|
switch(field) {
|
||||||
|
case DiveField::SUIT:
|
||||||
|
ui.suit->setText(QString(current_dive->suit));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void TabDiveEquipment::toggleTriggeredColumn()
|
void TabDiveEquipment::toggleTriggeredColumn()
|
||||||
{
|
{
|
||||||
QAction *action = qobject_cast<QAction *>(sender());
|
QAction *action = qobject_cast<QAction *>(sender());
|
||||||
|
@ -101,18 +135,24 @@ void TabDiveEquipment::updateData()
|
||||||
{
|
{
|
||||||
cylindersModel->updateDive();
|
cylindersModel->updateDive();
|
||||||
weightModel->updateDive();
|
weightModel->updateDive();
|
||||||
|
suitModel.updateModel();
|
||||||
|
|
||||||
ui.cylinders->view()->hideColumn(CylindersModel::DEPTH);
|
ui.cylinders->view()->hideColumn(CylindersModel::DEPTH);
|
||||||
if (get_dive_dc(&displayed_dive, dc_number)->divemode == CCR)
|
if (get_dive_dc(&displayed_dive, dc_number)->divemode == CCR)
|
||||||
ui.cylinders->view()->showColumn(CylindersModel::USE);
|
ui.cylinders->view()->showColumn(CylindersModel::USE);
|
||||||
else
|
else
|
||||||
ui.cylinders->view()->hideColumn(CylindersModel::USE);
|
ui.cylinders->view()->hideColumn(CylindersModel::USE);
|
||||||
|
if (current_dive && current_dive->suit)
|
||||||
|
ui.suit->setText(QString(current_dive->suit));
|
||||||
|
else
|
||||||
|
ui.suit->clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TabDiveEquipment::clear()
|
void TabDiveEquipment::clear()
|
||||||
{
|
{
|
||||||
cylindersModel->clear();
|
cylindersModel->clear();
|
||||||
weightModel->clear();
|
weightModel->clear();
|
||||||
|
ui.suit->clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TabDiveEquipment::addCylinder_clicked()
|
void TabDiveEquipment::addCylinder_clicked()
|
||||||
|
@ -256,3 +296,27 @@ void TabDiveEquipment::rejectChanges()
|
||||||
cylindersModel->updateDive();
|
cylindersModel->updateDive();
|
||||||
weightModel->updateDive();
|
weightModel->updateDive();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TabDiveEquipment::divesEdited(int i)
|
||||||
|
{
|
||||||
|
// No warning if only one dive was edited
|
||||||
|
if (i <= 1)
|
||||||
|
return;
|
||||||
|
ui.multiDiveWarningMessage->setCloseButtonVisible(false);
|
||||||
|
ui.multiDiveWarningMessage->setText(tr("Warning: edited %1 dives").arg(i));
|
||||||
|
ui.multiDiveWarningMessage->show();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TabDiveEquipment::on_suit_editingFinished()
|
||||||
|
{
|
||||||
|
if (!current_dive)
|
||||||
|
return;
|
||||||
|
divesEdited(Command::editSuit(ui.suit->text(), false));
|
||||||
|
}
|
||||||
|
|
||||||
|
void TabDiveEquipment::closeWarning()
|
||||||
|
{
|
||||||
|
ui.multiDiveWarningMessage->hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,8 @@
|
||||||
|
|
||||||
#include "TabBase.h"
|
#include "TabBase.h"
|
||||||
#include "ui_TabDiveEquipment.h"
|
#include "ui_TabDiveEquipment.h"
|
||||||
|
#include "qt-models/completionmodels.h"
|
||||||
|
#include "desktop-widgets/divelistview.h"
|
||||||
|
|
||||||
namespace Ui {
|
namespace Ui {
|
||||||
class TabDiveEquipment;
|
class TabDiveEquipment;
|
||||||
|
@ -21,15 +23,21 @@ public:
|
||||||
void clear() override;
|
void clear() override;
|
||||||
void acceptChanges();
|
void acceptChanges();
|
||||||
void rejectChanges();
|
void rejectChanges();
|
||||||
|
void divesEdited(int i);
|
||||||
|
void closeWarning();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
|
void divesChanged(const QVector<dive *> &dives, DiveField field);
|
||||||
void addCylinder_clicked();
|
void addCylinder_clicked();
|
||||||
void addWeight_clicked();
|
void addWeight_clicked();
|
||||||
void toggleTriggeredColumn();
|
void toggleTriggeredColumn();
|
||||||
void editCylinderWidget(const QModelIndex &index);
|
void editCylinderWidget(const QModelIndex &index);
|
||||||
void editWeightWidget(const QModelIndex &index);
|
void editWeightWidget(const QModelIndex &index);
|
||||||
|
void on_suit_editingFinished();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::TabDiveEquipment ui;
|
Ui::TabDiveEquipment ui;
|
||||||
|
SuitCompletionModel suitModel;
|
||||||
CylindersModel *cylindersModel;
|
CylindersModel *cylindersModel;
|
||||||
WeightModel *weightModel;
|
WeightModel *weightModel;
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,6 +6,9 @@
|
||||||
<string>Equipment</string>
|
<string>Equipment</string>
|
||||||
</attribute>
|
</attribute>
|
||||||
<layout class="QVBoxLayout" name="verticalLayout_10">
|
<layout class="QVBoxLayout" name="verticalLayout_10">
|
||||||
|
<item>
|
||||||
|
<widget class="KMessageWidget" name="multiDiveWarningMessage"/>
|
||||||
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QScrollArea" name="scrollArea">
|
<widget class="QScrollArea" name="scrollArea">
|
||||||
<property name="frameShape">
|
<property name="frameShape">
|
||||||
|
@ -61,11 +64,21 @@
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QSplitter" name="splitter">
|
<widget class="QSplitter" name="splitter">
|
||||||
<property name="orientation">
|
<property name="orientation">
|
||||||
<enum>Qt::Vertical</enum>
|
<enum>Qt::Vertical</enum>
|
||||||
</property>
|
</property>
|
||||||
<widget class="TableView" name="cylinders" native="true"/>
|
<widget class="TableView" name="cylinders" native="true"/>
|
||||||
|
<widget class="QLabel" name="suitText">
|
||||||
|
<property name="text">
|
||||||
|
<string>Suit</string>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
|
<widget class="QLineEdit" name="suit">
|
||||||
|
<property name="readOnly">
|
||||||
|
<bool>false</bool>
|
||||||
|
</property>
|
||||||
|
</widget>
|
||||||
<widget class="TableView" name="weights" native="true"/>
|
<widget class="TableView" name="weights" native="true"/>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|
|
@ -44,7 +44,6 @@
|
||||||
struct Completers {
|
struct Completers {
|
||||||
QCompleter *divemaster;
|
QCompleter *divemaster;
|
||||||
QCompleter *buddy;
|
QCompleter *buddy;
|
||||||
QCompleter *suit;
|
|
||||||
QCompleter *tags;
|
QCompleter *tags;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -126,15 +125,12 @@ MainTab::MainTab(QWidget *parent) : QTabWidget(parent),
|
||||||
Completers completers;
|
Completers completers;
|
||||||
completers.buddy = new QCompleter(&buddyModel, ui.buddy);
|
completers.buddy = new QCompleter(&buddyModel, ui.buddy);
|
||||||
completers.divemaster = new QCompleter(&diveMasterModel, ui.divemaster);
|
completers.divemaster = new QCompleter(&diveMasterModel, ui.divemaster);
|
||||||
completers.suit = new QCompleter(&suitModel, ui.suit);
|
|
||||||
completers.tags = new QCompleter(&tagModel, ui.tagWidget);
|
completers.tags = new QCompleter(&tagModel, ui.tagWidget);
|
||||||
completers.buddy->setCaseSensitivity(Qt::CaseInsensitive);
|
completers.buddy->setCaseSensitivity(Qt::CaseInsensitive);
|
||||||
completers.divemaster->setCaseSensitivity(Qt::CaseInsensitive);
|
completers.divemaster->setCaseSensitivity(Qt::CaseInsensitive);
|
||||||
completers.suit->setCaseSensitivity(Qt::CaseInsensitive);
|
|
||||||
completers.tags->setCaseSensitivity(Qt::CaseInsensitive);
|
completers.tags->setCaseSensitivity(Qt::CaseInsensitive);
|
||||||
ui.buddy->setCompleter(completers.buddy);
|
ui.buddy->setCompleter(completers.buddy);
|
||||||
ui.divemaster->setCompleter(completers.divemaster);
|
ui.divemaster->setCompleter(completers.divemaster);
|
||||||
ui.suit->setCompleter(completers.suit);
|
|
||||||
ui.tagWidget->setCompleter(completers.tags);
|
ui.tagWidget->setCompleter(completers.tags);
|
||||||
ui.diveNotesMessage->hide();
|
ui.diveNotesMessage->hide();
|
||||||
ui.multiDiveWarningMessage->hide();
|
ui.multiDiveWarningMessage->hide();
|
||||||
|
@ -308,9 +304,6 @@ void MainTab::divesChanged(const QVector<dive *> &dives, DiveField field)
|
||||||
case DiveField::VISIBILITY:
|
case DiveField::VISIBILITY:
|
||||||
ui.visibility->setCurrentStars(current_dive->visibility);
|
ui.visibility->setCurrentStars(current_dive->visibility);
|
||||||
break;
|
break;
|
||||||
case DiveField::SUIT:
|
|
||||||
ui.suit->setText(QString(current_dive->suit));
|
|
||||||
break;
|
|
||||||
case DiveField::NOTES:
|
case DiveField::NOTES:
|
||||||
updateNotes(current_dive);
|
updateNotes(current_dive);
|
||||||
break;
|
break;
|
||||||
|
@ -474,8 +467,6 @@ void MainTab::updateDiveInfo()
|
||||||
ui.DivemasterLabel->setVisible(false);
|
ui.DivemasterLabel->setVisible(false);
|
||||||
ui.buddy->setVisible(false);
|
ui.buddy->setVisible(false);
|
||||||
ui.BuddyLabel->setVisible(false);
|
ui.BuddyLabel->setVisible(false);
|
||||||
ui.suit->setVisible(false);
|
|
||||||
ui.SuitLabel->setVisible(false);
|
|
||||||
ui.rating->setVisible(false);
|
ui.rating->setVisible(false);
|
||||||
ui.RatingLabel->setVisible(false);
|
ui.RatingLabel->setVisible(false);
|
||||||
ui.visibility->setVisible(false);
|
ui.visibility->setVisible(false);
|
||||||
|
@ -530,8 +521,6 @@ void MainTab::updateDiveInfo()
|
||||||
ui.editDiveSiteButton->show();
|
ui.editDiveSiteButton->show();
|
||||||
ui.divemaster->setVisible(true);
|
ui.divemaster->setVisible(true);
|
||||||
ui.buddy->setVisible(true);
|
ui.buddy->setVisible(true);
|
||||||
ui.suit->setVisible(true);
|
|
||||||
ui.SuitLabel->setVisible(true);
|
|
||||||
ui.rating->setVisible(true);
|
ui.rating->setVisible(true);
|
||||||
ui.RatingLabel->setVisible(true);
|
ui.RatingLabel->setVisible(true);
|
||||||
ui.visibility->setVisible(true);
|
ui.visibility->setVisible(true);
|
||||||
|
@ -566,7 +555,6 @@ void MainTab::updateDiveInfo()
|
||||||
updateMode(current_dive);
|
updateMode(current_dive);
|
||||||
updateDiveSite(current_dive);
|
updateDiveSite(current_dive);
|
||||||
updateDateTime(current_dive);
|
updateDateTime(current_dive);
|
||||||
ui.suit->setText(current_dive->suit);
|
|
||||||
ui.divemaster->setText(current_dive->divemaster);
|
ui.divemaster->setText(current_dive->divemaster);
|
||||||
ui.buddy->setText(current_dive->buddy);
|
ui.buddy->setText(current_dive->buddy);
|
||||||
ui.airtemp->setText(get_temperature_string(current_dive->airtemp, true));
|
ui.airtemp->setText(get_temperature_string(current_dive->airtemp, true));
|
||||||
|
@ -589,7 +577,6 @@ void MainTab::updateDiveInfo()
|
||||||
ui.rating->setCurrentStars(0);
|
ui.rating->setCurrentStars(0);
|
||||||
ui.visibility->setCurrentStars(0);
|
ui.visibility->setCurrentStars(0);
|
||||||
ui.location->clear();
|
ui.location->clear();
|
||||||
ui.suit->clear();
|
|
||||||
ui.divemaster->clear();
|
ui.divemaster->clear();
|
||||||
ui.buddy->clear();
|
ui.buddy->clear();
|
||||||
ui.airtemp->clear();
|
ui.airtemp->clear();
|
||||||
|
@ -612,7 +599,6 @@ void MainTab::updateDiveInfo()
|
||||||
|
|
||||||
void MainTab::reload()
|
void MainTab::reload()
|
||||||
{
|
{
|
||||||
suitModel.updateModel();
|
|
||||||
buddyModel.updateModel();
|
buddyModel.updateModel();
|
||||||
diveMasterModel.updateModel();
|
diveMasterModel.updateModel();
|
||||||
tagModel.updateModel();
|
tagModel.updateModel();
|
||||||
|
@ -889,14 +875,6 @@ void MainTab::on_diveTripLocation_editingFinished()
|
||||||
Command::editTripLocation(currentTrip, ui.diveTripLocation->text());
|
Command::editTripLocation(currentTrip, ui.diveTripLocation->text());
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainTab::on_suit_editingFinished()
|
|
||||||
{
|
|
||||||
if (editMode == IGNORE || !current_dive)
|
|
||||||
return;
|
|
||||||
|
|
||||||
divesEdited(Command::editSuit(ui.suit->text(), false));
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainTab::on_notes_editingFinished()
|
void MainTab::on_notes_editingFinished()
|
||||||
{
|
{
|
||||||
if (!currentTrip && !current_dive)
|
if (!currentTrip && !current_dive)
|
||||||
|
|
|
@ -61,7 +61,6 @@ slots:
|
||||||
void on_locationPopupButton_clicked();
|
void on_locationPopupButton_clicked();
|
||||||
void on_divemaster_editingFinished();
|
void on_divemaster_editingFinished();
|
||||||
void on_buddy_editingFinished();
|
void on_buddy_editingFinished();
|
||||||
void on_suit_editingFinished();
|
|
||||||
void on_diveTripLocation_editingFinished();
|
void on_diveTripLocation_editingFinished();
|
||||||
void on_notes_editingFinished();
|
void on_notes_editingFinished();
|
||||||
void on_airtemp_editingFinished();
|
void on_airtemp_editingFinished();
|
||||||
|
@ -86,7 +85,6 @@ private:
|
||||||
EditMode editMode;
|
EditMode editMode;
|
||||||
BuddyCompletionModel buddyModel;
|
BuddyCompletionModel buddyModel;
|
||||||
DiveMasterCompletionModel diveMasterModel;
|
DiveMasterCompletionModel diveMasterModel;
|
||||||
SuitCompletionModel suitModel;
|
|
||||||
TagCompletionModel tagModel;
|
TagCompletionModel tagModel;
|
||||||
bool modified;
|
bool modified;
|
||||||
bool lastSelectedDive;
|
bool lastSelectedDive;
|
||||||
|
|
|
@ -337,13 +337,6 @@
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="0" column="2">
|
|
||||||
<widget class="QLabel" name="SuitLabel">
|
|
||||||
<property name="text">
|
|
||||||
<string>Suit</string>
|
|
||||||
</property>
|
|
||||||
</widget>
|
|
||||||
</item>
|
|
||||||
<item row="1" column="0" alignment="Qt::AlignVCenter">
|
<item row="1" column="0" alignment="Qt::AlignVCenter">
|
||||||
<widget class="StarWidget" name="rating" native="true">
|
<widget class="StarWidget" name="rating" native="true">
|
||||||
<property name="sizePolicy">
|
<property name="sizePolicy">
|
||||||
|
@ -371,17 +364,20 @@
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="2">
|
<item row="1" column="2">
|
||||||
<widget class="QLineEdit" name="suit">
|
<spacer>
|
||||||
<property name="sizePolicy">
|
<property name="orientation">
|
||||||
<sizepolicy hsizetype="Expanding" vsizetype="Fixed">
|
<enum>Qt::Horizontal</enum>
|
||||||
<horstretch>0</horstretch>
|
|
||||||
<verstretch>0</verstretch>
|
|
||||||
</sizepolicy>
|
|
||||||
</property>
|
</property>
|
||||||
<property name="readOnly">
|
<property name="sizeType">
|
||||||
<bool>false</bool>
|
<enum>QSizePolicy::Expanding</enum>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
<property name="sizeHint" stdset="0">
|
||||||
|
<size>
|
||||||
|
<width>20</width>
|
||||||
|
<height>20</height>
|
||||||
|
</size>
|
||||||
|
</property>
|
||||||
|
</spacer>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue