Files
sqlitebrowser/src/EditDialog.cpp

158 lines
3.7 KiB
C++

#include "EditDialog.h"
#include "ui_EditDialog.h"
#include <QTextStream>
#include <QMessageBox>
#include <QFileDialog>
#include "sqlitedb.h"
EditDialog::EditDialog(QWidget* parent)
: QDialog(parent),
ui(new Ui::EditDialog)
{
ui->setupUi(this);
reset();
}
EditDialog::~EditDialog()
{
delete ui;
}
void EditDialog::reset()
{
curRow = -1;
curCol = -1;
ui->editData->setPlainText("");
ui->editData->setFocus();
setDataType(kSQLiteMediaType_Void, 0);
}
void EditDialog::enableExport(bool enabled)
{
ui->buttonExport->setEnabled(enabled);
}
void EditDialog::setDataType(int type, int size)
{
dataType = type;
dataSize = size;
QString charstr;
switch(dataType)
{
case kSQLiteMediaType_String:
ui->labelType->setText(tr("Type of data currently in cell: Text / Numeric"));
ui->labelSize->setText(tr("%n char(s)", "", ui->editData->toPlainText().length()));
enableExport(true);
break;
case kSQLiteMediaType_Void:
ui->labelType->setText(tr("Type of data currently in cell: Empty"));
ui->labelSize->setText(tr(""));
enableExport(false);
break;
}
}
void EditDialog::closeEvent(QCloseEvent*)
{
emit goingAway();
}
void EditDialog::loadText(const QString& text, int row, int col)
{
ui->editData->setPlainText(text);
ui->editData->setFocus();
ui->editData->selectAll();
curRow = row;
curCol = col;
if(ui->editData->toPlainText().length() > 0)
setDataType(kSQLiteMediaType_String, 0);
else
setDataType(kSQLiteMediaType_Void, 0);
}
void EditDialog::importData()
{
int type = kSQLiteMediaType_Void;
QString fileName = QFileDialog::getOpenFileName(
this,
tr("Choose a file"),
defaultlocation,
tr("Text files(*.txt);;All files(*)"));
if(QFile::exists(fileName))
{
type = kSQLiteMediaType_String;
QFile file(fileName);
if(file.open(QIODevice::ReadOnly))
{
QTextStream stream(&file);
ui->editData->setPlainText(stream.readAll());
file.close();
}
setDataType(type, ui->editData->toPlainText().length());
}
}
void EditDialog::exportData()
{
QString filter;
switch (dataType)
{
case kSQLiteMediaType_String:
filter = tr("Text files(*.txt)");
break;
default:
return;
}
QString fileName = QFileDialog::getSaveFileName(
this,
tr("Choose a filename to export data"),
defaultlocation,
filter);
if(fileName.size() > 0)
{
switch (dataType)
{
case kSQLiteMediaType_String:
{
QFile file(fileName);
if(file.open(QIODevice::WriteOnly))
{
QTextStream stream(&file);
stream << ui->editData->toPlainText();
file.close();
}
}
break;
default:
return;
}
}
}
void EditDialog::clearData()
{
ui->editData->setPlainText("");
setDataType(kSQLiteMediaType_Void, 0);
}
void EditDialog::accept()
{
if(dataType == kSQLiteMediaType_String)
emit updateRecordText(curRow, curCol, ui->editData->toPlainText());
if (dataType == kSQLiteMediaType_Void)
emit updateRecordText(curRow, curCol, "");
emit goingAway();
}
void EditDialog::editTextChanged()
{
int newtype = kSQLiteMediaType_String;
if(ui->editData->toPlainText().length() == 0)
newtype = kSQLiteMediaType_Void;
setDataType(newtype, ui->editData->toPlainText().length());
}