mirror of
https://github.com/sqlitebrowser/sqlitebrowser.git
synced 2026-01-20 02:50:46 -06:00
158 lines
3.7 KiB
C++
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());
|
|
}
|