forked from francescmm/GitQlient
-
Notifications
You must be signed in to change notification settings - Fork 0
/
BranchDlg.cpp
82 lines (68 loc) · 2.45 KB
/
BranchDlg.cpp
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
74
75
76
77
78
79
80
81
82
#include "BranchDlg.h"
#include "ui_BranchDlg.h"
#include "git.h"
#include <QFile>
BranchDlg::BranchDlg(const BranchDlgConfig &config, QWidget *parent)
: QDialog(parent)
, ui(new Ui::BranchDlg)
, mConfig(config)
{
QFile styles(":/stylesheet.css");
if (styles.open(QIODevice::ReadOnly))
{
setStyleSheet(QString::fromUtf8(styles.readAll()));
styles.close();
}
ui->setupUi(this);
ui->leOldName->setText(mConfig.mCurrentBranchName);
if (mConfig.mDialogMode == BranchDlgMode::CREATE)
setWindowTitle("Create branch");
else if (mConfig.mDialogMode == BranchDlgMode::RENAME)
{
ui->pbAccept->setText(tr("Rename"));
setWindowTitle("Rename branch");
}
else if (mConfig.mDialogMode == BranchDlgMode::CREATE_CHECKOUT)
{
setWindowTitle("Create and checkout branch");
ui->leOldName->setHidden(true);
}
else if (mConfig.mDialogMode == BranchDlgMode::CREATE_FROM_COMMIT)
{
setWindowTitle("Create branch at commit");
ui->leOldName->setHidden(true);
}
connect(ui->leNewName, &QLineEdit::editingFinished, this, &BranchDlg::checkNewBranchName);
connect(ui->leNewName, &QLineEdit::returnPressed, this, &BranchDlg::accept);
connect(ui->pbAccept, &QPushButton::clicked, this, &BranchDlg::accept);
connect(ui->pbCancel, &QPushButton::clicked, this, &BranchDlg::reject);
}
BranchDlg::~BranchDlg()
{
delete ui;
}
void BranchDlg::checkNewBranchName()
{
if (ui->leNewName->text() == ui->leOldName->text())
ui->leNewName->setStyleSheet("border: 1px solid red;");
}
void BranchDlg::accept()
{
if (ui->leNewName->text() == ui->leOldName->text())
ui->leNewName->setStyleSheet("border: 1px solid red;");
else
{
QByteArray output;
QApplication::setOverrideCursor(QCursor(Qt::WaitCursor));
if (mConfig.mDialogMode == BranchDlgMode::CREATE)
mConfig.mGit->createBranchFromAnotherBranch(ui->leOldName->text(), ui->leNewName->text());
else if (mConfig.mDialogMode == BranchDlgMode::CREATE_CHECKOUT)
mConfig.mGit->checkoutNewLocalBranch(ui->leNewName->text());
else if (mConfig.mDialogMode == BranchDlgMode::RENAME)
mConfig.mGit->renameBranch(ui->leOldName->text(), ui->leNewName->text());
else if (mConfig.mDialogMode == BranchDlgMode::CREATE_FROM_COMMIT)
mConfig.mGit->createBranchAtCommit(ui->leOldName->text(), ui->leNewName->text());
QApplication::restoreOverrideCursor();
QDialog::accept();
}
}