Implemented reporting support via LimeReport
This commit is contained in:
@@ -38,6 +38,19 @@ void ReportDialog::setReports(ReportList reports)
|
||||
|
||||
ui->listReports->setModel(model);
|
||||
m_reports = reports;
|
||||
|
||||
connect(ui->listReports->selectionModel(), &QItemSelectionModel::currentRowChanged, [this](const QModelIndex, QModelIndex){
|
||||
ui->textDescription->setText(m_reports[ui->listReports->currentIndex().row()]->description());
|
||||
});
|
||||
|
||||
|
||||
if (!reports.isEmpty())
|
||||
{
|
||||
ui->btnPreview->setEnabled(true);
|
||||
ui->btnPrint->setEnabled(true);
|
||||
|
||||
ui->listReports->setCurrentIndex(model->index(0, 0));
|
||||
}
|
||||
}
|
||||
|
||||
void ReportDialog::on_btnPreview_clicked()
|
||||
@@ -48,3 +61,15 @@ void ReportDialog::on_btnPreview_clicked()
|
||||
viewer->setReport(m_reports[ui->listReports->currentIndex().row()]);
|
||||
viewer->openPreview();
|
||||
}
|
||||
|
||||
void ReportDialog::on_btnPrint_clicked()
|
||||
{
|
||||
ReportViewer viever;
|
||||
viever.setReport(m_reports[ui->listReports->currentIndex().row()]);
|
||||
viever.directPrint();
|
||||
}
|
||||
|
||||
void ReportDialog::on_btnClose_clicked()
|
||||
{
|
||||
close();
|
||||
}
|
||||
|
||||
@@ -21,6 +21,10 @@ public:
|
||||
private slots:
|
||||
void on_btnPreview_clicked();
|
||||
|
||||
void on_btnPrint_clicked();
|
||||
|
||||
void on_btnClose_clicked();
|
||||
|
||||
private:
|
||||
Ui::ReportDialog *ui;
|
||||
ReportList m_reports;
|
||||
|
||||
@@ -96,7 +96,11 @@
|
||||
<number>0</number>
|
||||
</property>
|
||||
<item>
|
||||
<widget class="QListView" name="listReports"/>
|
||||
<widget class="QListView" name="listReports">
|
||||
<property name="selectionBehavior">
|
||||
<enum>QAbstractItemView::SelectRows</enum>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
@@ -141,6 +145,9 @@
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QPushButton" name="btnPreview">
|
||||
<property name="enabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Preview</string>
|
||||
</property>
|
||||
@@ -152,6 +159,9 @@
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QPushButton" name="btnPrint">
|
||||
<property name="enabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Print</string>
|
||||
</property>
|
||||
|
||||
@@ -4,6 +4,7 @@
|
||||
#include "../context.h"
|
||||
|
||||
#include <QFile>
|
||||
#include <QPrinter>
|
||||
#include <LimeReport>
|
||||
|
||||
ReportViewer::ReportViewer(QWidget *parent) :
|
||||
@@ -11,6 +12,7 @@ ReportViewer::ReportViewer(QWidget *parent) :
|
||||
ui(new Ui::ReportViewer)
|
||||
{
|
||||
ui->setupUi(this);
|
||||
m_report = NULL;
|
||||
}
|
||||
|
||||
ReportViewer::~ReportViewer()
|
||||
@@ -33,6 +35,8 @@ void ReportViewer::setReport(ReportPtr report)
|
||||
|
||||
void ReportViewer::openPreview()
|
||||
{
|
||||
Q_ASSERT(m_report != NULL);
|
||||
|
||||
showMaximized();
|
||||
|
||||
m_prevWidget = m_report->createPreviewWidget(this);
|
||||
@@ -52,6 +56,22 @@ void ReportViewer::openPreview()
|
||||
m_prevWidget->refreshPages();
|
||||
}
|
||||
|
||||
void ReportViewer::directPrint(bool dialog)
|
||||
{
|
||||
Q_ASSERT(m_report != NULL);
|
||||
|
||||
QPrinter printer(QPrinter::HighResolution);
|
||||
|
||||
if (dialog || !printer.isValid())
|
||||
{
|
||||
m_report->printReport();
|
||||
}
|
||||
else
|
||||
{
|
||||
m_report->printReport(&printer);
|
||||
}
|
||||
}
|
||||
|
||||
void ReportViewer::on_btnClose_clicked()
|
||||
{
|
||||
close();
|
||||
|
||||
@@ -22,6 +22,7 @@ public:
|
||||
~ReportViewer();
|
||||
void setReport(ReportPtr report);
|
||||
void openPreview();
|
||||
void directPrint(bool dialog = true);
|
||||
|
||||
private slots:
|
||||
void on_btnClose_clicked();
|
||||
|
||||
Reference in New Issue
Block a user