Mercurial > hg > sonic-visualiser
changeset 484:1f3afbce6c2f integration_library
Merge from the default branch
author | mathieub <mathieu.barthet@eecs.qmul.ac.uk> |
---|---|
date | Mon, 17 Oct 2011 15:24:22 +0100 (2011-10-17) |
parents | e5c6aed2bf6b (current diff) a6cbec451508 (diff) |
children | b6c00a0a618e |
files | main/MainWindow.cpp |
diffstat | 1 files changed, 42 insertions(+), 18 deletions(-) [+] |
line wrap: on
line diff
--- a/main/MainWindow.cpp Mon Oct 17 14:05:54 2011 +0100 +++ b/main/MainWindow.cpp Mon Oct 17 15:24:22 2011 +0100 @@ -114,6 +114,7 @@ #include <QRegExp> #include <QScrollArea> #include <QDesktopServices> +#include <QDialogButtonBox> #include <QFileSystemWatcher> #include <iostream> @@ -2913,27 +2914,50 @@ void MainWindow::saveSessionAsTemplate() { - QString name = QInputDialog::getText - (this, tr("Enter template name"), - tr("Please enter a name for the saved template:")); - if (name == "") return; + QDialog *d = new QDialog; + d->setWindowTitle(tr("Enter template name")); + + QGridLayout *layout = new QGridLayout; + d->setLayout(layout); + + layout->addWidget(new QLabel(tr("Please enter a name for the saved template:")), + 0, 0); + QLineEdit *lineEdit = new QLineEdit; + layout->addWidget(lineEdit, 1, 0); + QCheckBox *makeDefault = new QCheckBox(tr("Set as default template for future audio files")); + layout->addWidget(makeDefault, 2, 0); - name.replace(QRegExp("[^\\w\\s\\.\"'-]"), "_"); - - ResourceFinder rf; - QString dir = rf.getResourceSaveDir("templates"); - QString filename = QString("%1/%2.svt").arg(dir).arg(name); - if (QFile(filename).exists()) { - if (QMessageBox::warning(this, - tr("Template file exists"), - tr("<b>Template file exists</b><p>The template \"%1\" already exists.<br>Overwrite it?").arg(name), - QMessageBox::Ok | QMessageBox::Cancel, - QMessageBox::Cancel) != QMessageBox::Ok) { - return; + QDialogButtonBox *bb = new QDialogButtonBox(QDialogButtonBox::Ok | + QDialogButtonBox::Cancel); + layout->addWidget(bb, 3, 0); + connect(bb, SIGNAL(accepted()), d, SLOT(accept())); + connect(bb, SIGNAL(accepted()), d, SLOT(accept())); + connect(bb, SIGNAL(rejected()), d, SLOT(reject())); + + if (d->exec() == QDialog::Accepted) { + + QString name = lineEdit->text(); + name.replace(QRegExp("[^\\w\\s\\.\"'-]"), "_"); + + ResourceFinder rf; + QString dir = rf.getResourceSaveDir("templates"); + QString filename = QString("%1/%2.svt").arg(dir).arg(name); + if (QFile(filename).exists()) { + if (QMessageBox::warning(this, + tr("Template file exists"), + tr("<b>Template file exists</b><p>The template \"%1\" already exists.<br>Overwrite it?").arg(name), + QMessageBox::Ok | QMessageBox::Cancel, + QMessageBox::Cancel) != QMessageBox::Ok) { + return; + } + } + + if (saveSessionTemplate(filename)) { + if (makeDefault->isChecked()) { + setDefaultSessionTemplate(name); + } } } - - saveSessionTemplate(filename); } void