0
0
mirror of https://github.com/fralx/LimeReport.git synced 2025-01-12 01:21:03 +03:00

Script editor fixed

This commit is contained in:
Arin Alex 2017-10-05 01:27:04 +03:00
parent 0f915a9581
commit a48d82c742
2 changed files with 27 additions and 15 deletions

View File

@ -25,10 +25,8 @@ ScriptEditor::~ScriptEditor()
delete ui; delete ui;
} }
void ScriptEditor::setReportEngine(ReportEnginePrivate* reportEngine) void ScriptEditor::initEditor(DataSourceManager* dm)
{ {
m_reportEngine = reportEngine;
DataSourceManager* dm = m_reportEngine->dataManager();
ScriptEngineManager& se = LimeReport::ScriptEngineManager::instance(); ScriptEngineManager& se = LimeReport::ScriptEngineManager::instance();
se.setDataManager(dm); se.setDataManager(dm);
@ -41,23 +39,24 @@ void ScriptEditor::setReportEngine(ReportEnginePrivate* reportEngine)
ui->twScriptEngine->setModel(se.model()); ui->twScriptEngine->setModel(se.model());
} }
if (ui->twScriptEngine->selectionModel()){
connect(ui->twScriptEngine->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
this, SLOT(slotOnCurrentChanged(QModelIndex,QModelIndex)));
}
}
void ScriptEditor::setReportEngine(ReportEnginePrivate* reportEngine)
{
m_reportEngine = reportEngine;
DataSourceManager* dm = m_reportEngine->dataManager();
initEditor(dm);
} }
void ScriptEditor::setReportPage(PageDesignIntf* page) void ScriptEditor::setReportPage(PageDesignIntf* page)
{ {
m_page = page; m_page = page;
DataSourceManager* dm = page->datasourceManager(); DataSourceManager* dm = page->datasourceManager();
ScriptEngineManager& se = LimeReport::ScriptEngineManager::instance(); initEditor(dm);
se.setDataManager(dm);
initCompleter();
if (dm){
if (dm->isNeedUpdateDatasourceModel())
dm->updateDatasourceModel();
ui->twData->setModel(dm->datasourcesModel());
ui->twScriptEngine->setModel(se.model());
}
} }
void ScriptEditor::setPageBand(BandDesignIntf* band) void ScriptEditor::setPageBand(BandDesignIntf* band)
@ -196,6 +195,14 @@ void ScriptEditor::on_twScriptEngine_doubleClicked(const QModelIndex &index)
ui->textEdit->setFocus(); ui->textEdit->setFocus();
} }
void ScriptEditor::slotOnCurrentChanged(const QModelIndex &to, const QModelIndex &)
{
LimeReport::ScriptEngineNode* node = static_cast<LimeReport::ScriptEngineNode*>(to.internalPointer());
if (node->type()==LimeReport::ScriptEngineNode::Function){
ui->lblDescription->setText(node->description());
}
}
} // namespace LimeReport } // namespace LimeReport

View File

@ -13,6 +13,7 @@ class ReportEnginePrivate;
class BaseDesignIntf; class BaseDesignIntf;
class PageDesignIntf; class PageDesignIntf;
class BandDesignIntf; class BandDesignIntf;
class DataSourceManager;
namespace Ui { namespace Ui {
class ScriptEditor; class ScriptEditor;
@ -36,9 +37,13 @@ public:
QString toPlainText(); QString toPlainText();
signals: signals:
void splitterMoved(int, int); void splitterMoved(int, int);
protected:
void initEditor(DataSourceManager* dm);
private slots: private slots:
void on_twData_doubleClicked(const QModelIndex &index); void on_twData_doubleClicked(const QModelIndex &index);
void on_twScriptEngine_doubleClicked(const QModelIndex &index); void on_twScriptEngine_doubleClicked(const QModelIndex &index);
void slotOnCurrentChanged(const QModelIndex& to, const QModelIndex&);
private: private:
void addItemToCompleater(const QString& pageName, BaseDesignIntf* item, QStringList& dataWords); void addItemToCompleater(const QString& pageName, BaseDesignIntf* item, QStringList& dataWords);
private: private: