summaryrefslogtreecommitdiffstats
path: root/qt-ui/locationinformation.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'qt-ui/locationinformation.cpp')
-rw-r--r--qt-ui/locationinformation.cpp173
1 files changed, 91 insertions, 82 deletions
diff --git a/qt-ui/locationinformation.cpp b/qt-ui/locationinformation.cpp
index 90d7dae6c..623a463c5 100644
--- a/qt-ui/locationinformation.cpp
+++ b/qt-ui/locationinformation.cpp
@@ -45,20 +45,20 @@ LocationInformationWidget::LocationInformationWidget(QWidget *parent) : QGroupBo
#ifndef NO_MARBLE
// Globe Management Code.
connect(this, &LocationInformationWidget::requestCoordinates,
- GlobeGPS::instance(), &GlobeGPS::prepareForGetDiveCoordinates);
+ GlobeGPS::instance(), &GlobeGPS::prepareForGetDiveCoordinates);
connect(this, &LocationInformationWidget::endRequestCoordinates,
- GlobeGPS::instance(), &GlobeGPS::endGetDiveCoordinates);
+ GlobeGPS::instance(), &GlobeGPS::endGetDiveCoordinates);
connect(GlobeGPS::instance(), &GlobeGPS::coordinatesChanged,
- this, &LocationInformationWidget::updateGpsCoordinates);
+ this, &LocationInformationWidget::updateGpsCoordinates);
connect(this, &LocationInformationWidget::endEditDiveSite,
- GlobeGPS::instance(), &GlobeGPS::repopulateLabels);
+ GlobeGPS::instance(), &GlobeGPS::repopulateLabels);
#endif
}
-bool LocationInformationWidget::eventFilter(QObject*, QEvent *ev)
+bool LocationInformationWidget::eventFilter(QObject *, QEvent *ev)
{
- if( ev->type() == QEvent::ContextMenu ) {
- QContextMenuEvent *ctx = (QContextMenuEvent*) ev;
+ if (ev->type() == QEvent::ContextMenu) {
+ QContextMenuEvent *ctx = (QContextMenuEvent *)ev;
QMenu contextMenu;
contextMenu.addAction(tr("Merge into current site"), this, SLOT(mergeSelectedDiveSites()));
contextMenu.exec(ctx->globalPos());
@@ -67,22 +67,23 @@ bool LocationInformationWidget::eventFilter(QObject*, QEvent *ev)
return false;
}
-void LocationInformationWidget::mergeSelectedDiveSites() {
+void LocationInformationWidget::mergeSelectedDiveSites()
+{
if (QMessageBox::warning(MainWindow::instance(), tr("Merging dive sites"),
- tr("You are about to merge dive sites, you can't undo that action \n Are you sure you want to continue?"),
- QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
+ tr("You are about to merge dive sites, you can't undo that action \n Are you sure you want to continue?"),
+ QMessageBox::Ok, QMessageBox::Cancel) != QMessageBox::Ok)
return;
QModelIndexList selection = ui.diveSiteListView->selectionModel()->selectedIndexes();
- uint32_t *selected_dive_sites = (uint32_t*) malloc(sizeof(uint32_t) * selection.count());
+ uint32_t *selected_dive_sites = (uint32_t *)malloc(sizeof(uint32_t) * selection.count());
int i = 0;
- Q_FOREACH(const QModelIndex& idx, selection) {
- selected_dive_sites[i] = (uint32_t) idx.data(LocationInformationModel::UUID_ROLE).toInt();
+ Q_FOREACH (const QModelIndex &idx, selection) {
+ selected_dive_sites[i] = (uint32_t)idx.data(LocationInformationModel::UUID_ROLE).toInt();
i++;
}
merge_dive_sites(displayed_dive_site.uuid, selected_dive_sites, i);
LocationInformationModel::instance()->update();
- QSortFilterProxyModel *m = (QSortFilterProxyModel *) ui.diveSiteListView->model();
+ QSortFilterProxyModel *m = (QSortFilterProxyModel *)ui.diveSiteListView->model();
m->invalidate();
free(selected_dive_sites);
}
@@ -177,7 +178,7 @@ void LocationInformationWidget::showEvent(QShowEvent *ev)
{
if (displayed_dive_site.uuid) {
updateLabels();
- QSortFilterProxyModel *m = qobject_cast<QSortFilterProxyModel*>(ui.diveSiteListView->model());
+ QSortFilterProxyModel *m = qobject_cast<QSortFilterProxyModel *>(ui.diveSiteListView->model());
emit startFilterDiveSite(displayed_dive_site.uuid);
if (m)
m->invalidate();
@@ -194,9 +195,7 @@ void LocationInformationWidget::markChangedWidget(QWidget *w)
if (!modified)
enableEdition();
qApp->palette().color(QPalette::Text).getHslF(&h, &s, &l, &a);
- p.setBrush(QPalette::Base, (l <= 0.3) ? QColor(Qt::yellow).lighter()
- : (l <= 0.6) ? QColor(Qt::yellow).light()
- : /* else */ QColor(Qt::yellow).darker(300));
+ p.setBrush(QPalette::Base, (l <= 0.3) ? QColor(Qt::yellow).lighter() : (l <= 0.6) ? QColor(Qt::yellow).light() : /* else */ QColor(Qt::yellow).darker(300));
w->setPalette(p);
modified = true;
}
@@ -217,7 +216,7 @@ void LocationInformationWidget::enableEdition()
ui.diveSiteMessage->setText(tr("You are editing a dive site"));
}
-void LocationInformationWidget::on_diveSiteCoordinates_textChanged(const QString& text)
+void LocationInformationWidget::on_diveSiteCoordinates_textChanged(const QString &text)
{
uint lat = displayed_dive_site.latitude.udeg;
uint lon = displayed_dive_site.longitude.udeg;
@@ -232,13 +231,13 @@ void LocationInformationWidget::on_diveSiteCoordinates_textChanged(const QString
}
}
-void LocationInformationWidget::on_diveSiteDescription_textChanged(const QString& text)
+void LocationInformationWidget::on_diveSiteDescription_textChanged(const QString &text)
{
if (!same_string(qPrintable(text), displayed_dive_site.description))
markChangedWidget(ui.diveSiteDescription);
}
-void LocationInformationWidget::on_diveSiteName_textChanged(const QString& text)
+void LocationInformationWidget::on_diveSiteName_textChanged(const QString &text)
{
if (!same_string(qPrintable(text), displayed_dive_site.name))
markChangedWidget(ui.diveSiteName);
@@ -246,7 +245,7 @@ void LocationInformationWidget::on_diveSiteName_textChanged(const QString& text)
void LocationInformationWidget::on_diveSiteNotes_textChanged()
{
- if (!same_string(qPrintable(ui.diveSiteNotes->toPlainText()), displayed_dive_site.notes))
+ if (!same_string(qPrintable(ui.diveSiteNotes->toPlainText()), displayed_dive_site.notes))
markChangedWidget(ui.diveSiteNotes);
}
@@ -268,21 +267,20 @@ void LocationInformationWidget::reverseGeocode()
DiveLocationFilterProxyModel::DiveLocationFilterProxyModel(QObject *parent)
{
-
}
DiveLocationLineEdit *location_line_edit = 0;
-bool DiveLocationFilterProxyModel::filterAcceptsRow(int source_row, const QModelIndex& source_parent) const
+bool DiveLocationFilterProxyModel::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const
{
- if(source_row == 0)
+ if (source_row == 0)
return true;
QString sourceString = sourceModel()->index(source_row, DiveLocationModel::NAME).data(Qt::DisplayRole).toString();
return sourceString.toLower().startsWith(location_line_edit->text().toLower());
}
-bool DiveLocationFilterProxyModel::lessThan(const QModelIndex& source_left, const QModelIndex& source_right) const
+bool DiveLocationFilterProxyModel::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const
{
return source_left.data().toString() <= source_right.data().toString();
}
@@ -299,57 +297,66 @@ void DiveLocationModel::resetModel()
endResetModel();
}
-QVariant DiveLocationModel::data(const QModelIndex& index, int role) const
+QVariant DiveLocationModel::data(const QModelIndex &index, int role) const
{
static const QIcon plusIcon(":plus");
static const QIcon geoCode(":geocode");
- if(index.row() <= 1) { // two special cases.
- if(index.column() == UUID) {
+ if (index.row() <= 1) { // two special cases.
+ if (index.column() == UUID) {
return RECENTLY_ADDED_DIVESITE;
}
- switch(role) {
- case Qt::DisplayRole : return new_ds_value[index.row()];
- case Qt::ToolTipRole : return "Create a new dive site";
- case Qt::DecorationRole : return plusIcon;
+ switch (role) {
+ case Qt::DisplayRole:
+ return new_ds_value[index.row()];
+ case Qt::ToolTipRole:
+ return "Create a new dive site";
+ case Qt::DecorationRole:
+ return plusIcon;
}
}
// The dive sites are -2 because of the first two items.
struct dive_site *ds = get_dive_site(index.row() - 2);
- switch(role) {
- case Qt::EditRole:
- case Qt::DisplayRole :
- switch(index.column()) {
- case UUID: return ds->uuid;
- case NAME: return ds->name;
- case LATITUDE: return ds->latitude.udeg;
- case LONGITUDE: return ds->longitude.udeg;
- case DESCRIPTION: return ds->description;
- case NOTES: return ds->name;
- }
- break;
- case Qt::DecorationRole : {
- if (dive_site_has_gps_location(ds))
- return geoCode;
+ switch (role) {
+ case Qt::EditRole:
+ case Qt::DisplayRole:
+ switch (index.column()) {
+ case UUID:
+ return ds->uuid;
+ case NAME:
+ return ds->name;
+ case LATITUDE:
+ return ds->latitude.udeg;
+ case LONGITUDE:
+ return ds->longitude.udeg;
+ case DESCRIPTION:
+ return ds->description;
+ case NOTES:
+ return ds->name;
}
+ break;
+ case Qt::DecorationRole: {
+ if (dive_site_has_gps_location(ds))
+ return geoCode;
+ }
}
return QVariant();
}
-int DiveLocationModel::columnCount(const QModelIndex& parent) const
+int DiveLocationModel::columnCount(const QModelIndex &parent) const
{
return COLUMNS;
}
-int DiveLocationModel::rowCount(const QModelIndex& parent) const
+int DiveLocationModel::rowCount(const QModelIndex &parent) const
{
return dive_site_table.nr + 2;
}
-bool DiveLocationModel::setData(const QModelIndex& index, const QVariant& value, int role)
+bool DiveLocationModel::setData(const QModelIndex &index, const QVariant &value, int role)
{
- if(!index.isValid())
+ if (!index.isValid())
return false;
if (index.row() > 1)
return false;
@@ -361,7 +368,9 @@ bool DiveLocationModel::setData(const QModelIndex& index, const QVariant& value,
}
DiveLocationLineEdit::DiveLocationLineEdit(QWidget *parent) : QLineEdit(parent),
- proxy(new DiveLocationFilterProxyModel()), model(new DiveLocationModel()), view(new DiveLocationListView())
+ proxy(new DiveLocationFilterProxyModel()),
+ model(new DiveLocationModel()),
+ view(new DiveLocationListView())
{
currUuid = 0;
location_line_edit = this;
@@ -390,27 +399,27 @@ DiveLocationLineEdit::DiveLocationLineEdit(QWidget *parent) : QLineEdit(parent),
bool DiveLocationLineEdit::eventFilter(QObject *o, QEvent *e)
{
- if(e->type() == QEvent::KeyPress) {
- QKeyEvent *keyEv = (QKeyEvent*) e;
+ if (e->type() == QEvent::KeyPress) {
+ QKeyEvent *keyEv = (QKeyEvent *)e;
if (keyEv->key() == Qt::Key_Escape) {
view->hide();
return true;
}
- if(keyEv->key() == Qt::Key_Return ||
- keyEv->key() == Qt::Key_Enter) {
+ if (keyEv->key() == Qt::Key_Return ||
+ keyEv->key() == Qt::Key_Enter) {
view->hide();
return false;
}
- if (keyEv->key() == Qt::Key_Tab){
- itemActivated(view->currentIndex());
- view->hide();
- return false;
- }
+ if (keyEv->key() == Qt::Key_Tab) {
+ itemActivated(view->currentIndex());
+ view->hide();
+ return false;
+ }
event(e);
- } else if(e->type() == QEvent::MouseButtonPress ) {
+ } else if (e->type() == QEvent::MouseButtonPress) {
if (!view->underMouse()) {
view->hide();
return true;
@@ -420,25 +429,25 @@ bool DiveLocationLineEdit::eventFilter(QObject *o, QEvent *e)
return false;
}
-void DiveLocationLineEdit::focusOutEvent(QFocusEvent* ev)
+void DiveLocationLineEdit::focusOutEvent(QFocusEvent *ev)
{
if (!view->isVisible()) {
QLineEdit::focusOutEvent(ev);
}
}
-void DiveLocationLineEdit::itemActivated(const QModelIndex& index)
+void DiveLocationLineEdit::itemActivated(const QModelIndex &index)
{
QModelIndex uuidIndex = index.model()->index(index.row(), DiveLocationModel::UUID);
uint32_t uuid = uuidIndex.data().toInt();
currType = uuid == 1 ? NEW_DIVE_SITE : EXISTING_DIVE_SITE;
currUuid = uuid;
setText(index.data().toString());
- if(currUuid == NEW_DIVE_SITE)
+ if (currUuid == NEW_DIVE_SITE)
qDebug() << "Setting a New dive site";
else
qDebug() << "Setting a Existing dive site";
- if(view->isVisible())
+ if (view->isVisible())
view->hide();
emit diveSiteSelected(currUuid);
}
@@ -448,10 +457,11 @@ void DiveLocationLineEdit::refreshDiveSiteCache()
model->resetModel();
}
-static struct dive_site *get_dive_site_name_start_which_str(const QString& str) {
+static struct dive_site *get_dive_site_name_start_which_str(const QString &str)
+{
struct dive_site *ds;
int i;
- for_each_dive_site(i,ds) {
+ for_each_dive_site (i, ds) {
QString dsName(ds->name);
if (dsName.toLower().startsWith(str.toLower())) {
return ds;
@@ -460,7 +470,7 @@ static struct dive_site *get_dive_site_name_start_which_str(const QString& str)
return NULL;
}
-void DiveLocationLineEdit::setTemporaryDiveSiteName(const QString& s)
+void DiveLocationLineEdit::setTemporaryDiveSiteName(const QString &s)
{
QModelIndex i0 = model->index(0, DiveLocationModel::NAME);
QModelIndex i1 = model->index(1, DiveLocationModel::NAME);
@@ -474,7 +484,7 @@ void DiveLocationLineEdit::setTemporaryDiveSiteName(const QString& s)
i1_name = QString(ds->name);
}
- model->setData(i1, i1_name );
+ model->setData(i1, i1_name);
proxy->invalidate();
fixPopupPosition();
if (!view->isVisible())
@@ -484,12 +494,12 @@ void DiveLocationLineEdit::setTemporaryDiveSiteName(const QString& s)
void DiveLocationLineEdit::keyPressEvent(QKeyEvent *ev)
{
QLineEdit::keyPressEvent(ev);
- if(ev->key() != Qt::Key_Left &&
- ev->key() != Qt::Key_Right &&
- ev->key() != Qt::Key_Escape &&
- ev->key() != Qt::Key_Return ) {
+ if (ev->key() != Qt::Key_Left &&
+ ev->key() != Qt::Key_Right &&
+ ev->key() != Qt::Key_Escape &&
+ ev->key() != Qt::Key_Return) {
- if(ev->key() != Qt::Key_Up && ev->key() != Qt::Key_Down) {
+ if (ev->key() != Qt::Key_Up && ev->key() != Qt::Key_Down) {
currType = NEW_DIVE_SITE;
currUuid = RECENTLY_ADDED_DIVESITE;
} else {
@@ -533,19 +543,19 @@ void DiveLocationLineEdit::fixPopupPosition()
}
view->setGeometry(pos.x(), pos.y(), w, h);
- if(!view->currentIndex().isValid()) {
- view->setCurrentIndex(view->model()->index(0,1));
+ if (!view->currentIndex().isValid()) {
+ view->setCurrentIndex(view->model()->index(0, 1));
}
}
void DiveLocationLineEdit::setCurrentDiveSiteUuid(uint32_t uuid)
{
currUuid = uuid;
- if(uuid == 0) {
+ if (uuid == 0) {
currType = NO_DIVE_SITE;
}
struct dive_site *ds = get_dive_site_by_uuid(uuid);
- if(!ds)
+ if (!ds)
clear();
setText(ds->name);
}
@@ -572,10 +582,9 @@ uint32_t DiveLocationLineEdit::currDiveSiteUuid() const
DiveLocationListView::DiveLocationListView(QWidget *parent)
{
-
}
-void DiveLocationListView::currentChanged(const QModelIndex& current, const QModelIndex& previous)
+void DiveLocationListView::currentChanged(const QModelIndex &current, const QModelIndex &previous)
{
QListView::currentChanged(current, previous);
emit currentIndexChanged(current);