summaryrefslogtreecommitdiffstats
path: root/examples/sql/sqlbrowser/qsqlconnectiondialog.cpp
blob: 9f6b8c8169aff276e942917dcfc7a80f3b2d61ec (plain)
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
68
69
70
71
72
73
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause

#include "qsqlconnectiondialog.h"
#include <ui_qsqlconnectiondialog.h>

#include <QCheckBox>
#include <QMessageBox>
#include <QPushButton>
#include <QSqlDatabase>

QSqlConnectionDialog::QSqlConnectionDialog(QWidget *parent)
    : QDialog(parent)
    , m_ui{std::make_unique<Ui::QSqlConnectionDialogUi>()}
{
    m_ui->setupUi(this);

    QStringList drivers = QSqlDatabase::drivers();

    if (!drivers.contains("QSQLITE"))
        m_ui->dbCheckBox->setEnabled(false);

    m_ui->comboDriver->addItems(drivers);
}

QSqlConnectionDialog::~QSqlConnectionDialog()
    = default;

QString QSqlConnectionDialog::driverName() const
{
    return m_ui->comboDriver->currentText();
}

QString QSqlConnectionDialog::databaseName() const
{
    return m_ui->editDatabase->text();
}

QString QSqlConnectionDialog::userName() const
{
    return m_ui->editUsername->text();
}

QString QSqlConnectionDialog::password() const
{
    return m_ui->editPassword->text();
}

QString QSqlConnectionDialog::hostName() const
{
    return m_ui->editHostname->text();
}

int QSqlConnectionDialog::port() const
{
    return m_ui->portSpinBox->value();
}

bool QSqlConnectionDialog::useInMemoryDatabase() const
{
    return m_ui->dbCheckBox->isChecked();
}

void QSqlConnectionDialog::accept()
{
    if (m_ui->comboDriver->currentText().isEmpty()) {
        QMessageBox::information(this, tr("No database driver selected"),
                                 tr("Please select a database driver"));
        m_ui->comboDriver->setFocus();
    } else {
        QDialog::accept();
    }
}