From ab118549e1a912ce78bcc17e191a11521d1a81d6 Mon Sep 17 00:00:00 2001 From: Rodrigo Torres Date: Wed, 22 Jan 2020 12:05:16 -0300 Subject: [PATCH 1/3] Update .travis.yml --- .travis.yml | 102 +++++++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 97 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml index f879261..e708932 100644 --- a/.travis.yml +++ b/.travis.yml @@ -498,7 +498,7 @@ matrix: - make - make check - - env: Qt5.12.3_Ubuntu_18.04 + - env: Qt5.12.6_Ubuntu_18.04 os: linux dist: bionic language: cpp @@ -507,7 +507,7 @@ matrix: addons: apt: sources: - - sourceline: 'ppa:beineri/opt-qt-5.12.3-bionic' + - sourceline: 'ppa:beineri/opt-qt-5.12.6-bionic' packages: - qt512base - qt512script @@ -521,7 +521,7 @@ matrix: - make - make check - - env: Qt5.12.3_Ubuntu_18.04 + - env: Qt5.12.6_Ubuntu_18.04 os: linux dist: bionic language: cpp @@ -530,7 +530,7 @@ matrix: addons: apt: sources: - - sourceline: 'ppa:beineri/opt-qt-5.12.3-bionic' + - sourceline: 'ppa:beineri/opt-qt-5.12.6-bionic' packages: - qt512base - qt512script @@ -542,7 +542,99 @@ matrix: - source /opt/qt512/bin/qt512-env.sh - /opt/qt512/bin/qmake -r limereport.pro - make - - make check + - make check + + - env: Qt5.13.2_Ubuntu_18.04 + os: linux + dist: bionic + language: cpp + compiler: gcc + cache: ccache + addons: + apt: + sources: + - sourceline: 'ppa:beineri/opt-qt-5.13.2-bionic' + packages: + - qt513base + - qt513script + - qt513tools + - mesa-common-dev + - libgl1-mesa-dev + + script: + - source /opt/qt513/bin/qt513-env.sh + - /opt/qt513/bin/qmake -r limereport.pro + - make + - make check + + - env: Qt5.13.2_Ubuntu_18.04 + os: linux + dist: bionic + language: cpp + compiler: clang + cache: ccache + addons: + apt: + sources: + - sourceline: 'ppa:beineri/opt-qt-5.13.2-bionic' + packages: + - qt513base + - qt513script + - qt513tools + - mesa-common-dev + - libgl1-mesa-dev + + script: + - source /opt/qt513/bin/qt513-env.sh + - /opt/qt513/bin/qmake -r limereport.pro + - make + - make check + + - env: Qt5.14.0_Ubuntu_18.04 + os: linux + dist: bionic + language: cpp + compiler: gcc + cache: ccache + addons: + apt: + sources: + - sourceline: 'ppa:beineri/opt-qt-5.14.0-bionic' + packages: + - qt514base + - qt514script + - qt514tools + - mesa-common-dev + - libgl1-mesa-dev + + script: + - source /opt/qt514/bin/qt514-env.sh + - /opt/qt514/bin/qmake -r limereport.pro + - make + - make check + + - env: Qt5.14.0_Ubuntu_18.04 + os: linux + dist: bionic + language: cpp + compiler: clang + cache: ccache + addons: + apt: + sources: + - sourceline: 'ppa:beineri/opt-qt-5.14.0-bionic' + packages: + - qt514base + - qt514script + - qt514tools + - mesa-common-dev + - libgl1-mesa-dev + + script: + - source /opt/qt514/bin/qt514-env.sh + - /opt/qt514/bin/qmake -r limereport.pro + - make + - make check notifications: email: false \ No newline at end of file From 85b3c940d418841c448e0e6cff348b88d3e99a1c Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Fri, 31 Jan 2020 20:00:28 +0300 Subject: [PATCH 2/3] ChartItem: Series property editor has been added --- limereport/base/lrattribsabstractfactory.h | 6 +-- limereport/designer.pri | 2 + limereport/items/lrchartitem.cpp | 2 +- limereport/items/lrchartitem.h | 7 +-- limereport/items/lrchartitemeditor.cpp | 2 +- limereport/items/lrchartitemeditor.h | 4 ++ .../lrobjectinspectorwidget.cpp | 8 ++- .../objectinspector/lrobjectitemmodel.cpp | 10 ++-- .../propertyItems/lrimagepropitem.cpp | 4 +- .../propertyItems/lrseriespropitem.cpp | 51 +++++++++++++++++++ .../propertyItems/lrseriespropitem.h | 41 +++++++++++++++ .../propertyItems/lrstringpropitem.cpp | 2 +- 12 files changed, 121 insertions(+), 18 deletions(-) create mode 100644 limereport/objectinspector/propertyItems/lrseriespropitem.cpp create mode 100644 limereport/objectinspector/propertyItems/lrseriespropitem.h diff --git a/limereport/base/lrattribsabstractfactory.h b/limereport/base/lrattribsabstractfactory.h index d760aa5..3499253 100644 --- a/limereport/base/lrattribsabstractfactory.h +++ b/limereport/base/lrattribsabstractfactory.h @@ -54,11 +54,11 @@ private: friend class Singleton< AttribsAbstractFactory< AbstractProduct,IdentifierType,ProductCreator,Attribs > >; public: bool registerCreator(const IdentifierType& id, Attribs attribs, ProductCreator creator){ - return (m_factoryMap.insert(id,creator).value()==creator)&& - (m_attribsMap.insert(id,attribs).value()==attribs); + return (m_factoryMap.insert(id,creator).value() == creator) && + (m_attribsMap.insert(id,attribs).value() == attribs); } bool unregisterCreator(const IdentifierType& id){ - return (m_factoryMap.remove(id)==1)&&(m_attribsMap.remove(id)==1); + return (m_factoryMap.remove(id) == 1) && (m_attribsMap.remove(id) == 1); } ProductCreator objectCreator(const IdentifierType& id){ if (m_factoryMap.contains(id)){ diff --git a/limereport/designer.pri b/limereport/designer.pri index 1c7e279..deef2d8 100644 --- a/limereport/designer.pri +++ b/limereport/designer.pri @@ -28,6 +28,7 @@ SOURCES += \ $$REPORT_PATH/objectinspector/propertyItems/lrgroupfieldpropitem.cpp \ $$REPORT_PATH/objectinspector/propertyItems/lrcontentpropitem.cpp \ $$REPORT_PATH/objectinspector/propertyItems/lrmarginpropitem.cpp \ + $$REPORT_PATH/objectinspector/propertyItems/lrseriespropitem.cpp \ $$REPORT_PATH/objectinspector/editors/lrtextitempropertyeditor.cpp \ $$REPORT_PATH/objectinspector/editors/lrcomboboxeditor.cpp \ $$REPORT_PATH/objectinspector/editors/lrcheckboxeditor.cpp \ @@ -71,6 +72,7 @@ HEADERS += \ $$REPORT_PATH/objectinspector/propertyItems/lrqrealpropitem.h \ $$REPORT_PATH/objectinspector/propertyItems/lrcolorpropitem.h \ $$REPORT_PATH/objectinspector/propertyItems/lrmarginpropitem.h \ + $$REPORT_PATH/objectinspector/propertyItems/lrseriespropitem.h \ $$REPORT_PATH/objectinspector/editors/lrtextitempropertyeditor.h \ $$REPORT_PATH/objectinspector/editors/lrcomboboxeditor.h \ $$REPORT_PATH/objectinspector/editors/lrcheckboxeditor.h \ diff --git a/limereport/items/lrchartitem.cpp b/limereport/items/lrchartitem.cpp index b80e700..5a366bb 100644 --- a/limereport/items/lrchartitem.cpp +++ b/limereport/items/lrchartitem.cpp @@ -251,7 +251,7 @@ QWidget *ChartItem::defaultEditor() QSettings* l_settings = (page()->settings() != 0) ? page()->settings() : (page()->reportEditor()!=0) ? page()->reportEditor()->settings() : 0; - QWidget* editor = new ChartItemEditor(this,page(),l_settings); + QWidget* editor = new ChartItemEditor(this, page(), l_settings); editor->setAttribute(Qt::WA_DeleteOnClose); return editor; } diff --git a/limereport/items/lrchartitem.h b/limereport/items/lrchartitem.h index bd1ca40..8929668 100644 --- a/limereport/items/lrchartitem.h +++ b/limereport/items/lrchartitem.h @@ -117,7 +117,7 @@ class ChartItem : public LimeReport::ItemDesignIntf Q_ENUMS(LegendAlign) Q_ENUMS(TitleAlign) Q_ENUMS(ChartType) - Q_PROPERTY(ACollectionProperty series READ fakeCollectionReader) + Q_PROPERTY(ACollectionProperty series READ fakeCollectionReader WRITE setSeries) Q_PROPERTY(QString datasource READ datasource WRITE setDatasource) Q_PROPERTY(QString chartTitle READ chartTitle WRITE setChartTitle) Q_PROPERTY(bool drawLegendBorder READ drawLegendBorder WRITE setDrawLegendBorder) @@ -163,6 +163,7 @@ public: QList labels() const; void setLabels(const QList &labels); + QWidget* defaultEditor(); protected: void paintChartTitle(QPainter* painter, QRectF titleRect); @@ -173,9 +174,9 @@ protected: QObject* elementAt(const QString& collectionName,int index); void collectionLoadFinished(const QString& collectionName){Q_UNUSED(collectionName)} void updateItemSize(DataSourceManager *dataManager, RenderPass, int); - void fillLabels(IDataSource* dataSource); - QWidget* defaultEditor(); + void fillLabels(IDataSource* dataSource); bool isNeedUpdateSize(RenderPass pass) const; + void setSeries(ACollectionProperty series){Q_UNUSED(series)} private: QList m_series; QString m_datasource; diff --git a/limereport/items/lrchartitemeditor.cpp b/limereport/items/lrchartitemeditor.cpp index f772632..92ea3fb 100644 --- a/limereport/items/lrchartitemeditor.cpp +++ b/limereport/items/lrchartitemeditor.cpp @@ -189,9 +189,9 @@ void ChartItemEditor::on_splitter_splitterMoved(int , int ) #endif } - void ChartItemEditor::on_pbOk_clicked() { + emit editingFinished(); close(); } diff --git a/limereport/items/lrchartitemeditor.h b/limereport/items/lrchartitemeditor.h index a406fc8..f24123f 100644 --- a/limereport/items/lrchartitemeditor.h +++ b/limereport/items/lrchartitemeditor.h @@ -25,6 +25,10 @@ public: protected: void resizeEvent(QResizeEvent *); void moveEvent(QMoveEvent *); + +signals: + void editingFinished(); + private slots: void on_splitter_splitterMoved(int, int); void on_pbOk_clicked(); diff --git a/limereport/objectinspector/lrobjectinspectorwidget.cpp b/limereport/objectinspector/lrobjectinspectorwidget.cpp index 3997e16..1a3be38 100644 --- a/limereport/objectinspector/lrobjectinspectorwidget.cpp +++ b/limereport/objectinspector/lrobjectinspectorwidget.cpp @@ -95,13 +95,17 @@ void ObjectInspectorTreeView::mousePressEvent(QMouseEvent *event) if ((event->button()==Qt::LeftButton)){ QModelIndex index=indexAt(event->pos()); if (index.isValid()){ - if (event->pos().x()pos().x() < indentation()) { if (!nodeFromIndex(index)->isHaveValue()) setExpanded(index,!isExpanded(index)); } else { if ((index.column()==1)&&(!nodeFromIndex(index)->isHaveChildren())) { setCurrentIndex(index); - edit(index); + + Qt::ItemFlags flags = index.model()->flags(index); + if ( !(((flags & Qt::ItemIsEditable) == 0) || ((flags & Qt::ItemIsEnabled) == 0)) ) + edit(index); + return ; } } diff --git a/limereport/objectinspector/lrobjectitemmodel.cpp b/limereport/objectinspector/lrobjectitemmodel.cpp index eb09d92..0f725db 100644 --- a/limereport/objectinspector/lrobjectitemmodel.cpp +++ b/limereport/objectinspector/lrobjectitemmodel.cpp @@ -363,14 +363,14 @@ QModelIndex QObjectPropertyModel::parent(const QModelIndex &child) const Qt::ItemFlags QObjectPropertyModel::flags(const QModelIndex &index) const { - if ((index.column()==1)&&(!nodeFromIndex(index)->isValueReadonly())) return Qt::ItemIsEnabled | Qt::ItemIsEditable | Qt::ItemIsSelectable; + if ((index.column() == 1) && (!nodeFromIndex(index)->isValueReadonly())) return Qt::ItemIsEnabled | Qt::ItemIsEditable | Qt::ItemIsSelectable; else return Qt::ItemIsEnabled | Qt::ItemIsSelectable; } CreatePropItem QObjectPropertyModel::propertyItemCreator(QMetaProperty prop) { - CreatePropItem creator=0; - creator=ObjectPropFactory::instance().objectCreator(APropIdent(prop.name(),prop.enclosingMetaObject()->className())); + CreatePropItem creator = 0; + creator = ObjectPropFactory::instance().objectCreator(APropIdent(prop.name(),prop.enclosingMetaObject()->className())); if (!creator){ if (prop.isFlagType()){ creator=ObjectPropFactory::instance().objectCreator(APropIdent("flags","")); @@ -390,7 +390,7 @@ CreatePropItem QObjectPropertyModel::propertyItemCreator(QMetaProperty prop) return 0; } } - creator=ObjectPropFactory::instance().objectCreator(APropIdent(prop.typeName(),"")); + creator = ObjectPropFactory::instance().objectCreator(APropIdent(prop.typeName(),"")); if (!creator) {qDebug()<<"Editor for propperty name = \""<property(prop.name()), parent, - !(prop.isWritable()&&prop.isDesignable()) + !(prop.isWritable() && prop.isDesignable()) ); } else { propertyItem=new ObjectPropItem( diff --git a/limereport/objectinspector/propertyItems/lrimagepropitem.cpp b/limereport/objectinspector/propertyItems/lrimagepropitem.cpp index c6d324b..e44797d 100644 --- a/limereport/objectinspector/propertyItems/lrimagepropitem.cpp +++ b/limereport/objectinspector/propertyItems/lrimagepropitem.cpp @@ -48,12 +48,12 @@ QWidget* ImagePropItem::createProperyEditor(QWidget *parent) const QString ImagePropItem::displayValue() const { - return (propertyValue().isNull())?"":"Picture"; + return (propertyValue().isNull()) ? "" : QObject::tr("image"); } void ImagePropItem::setPropertyEditorData(QWidget *propertyEditor, const QModelIndex &) const { - ImageEditor *editor =qobject_cast(propertyEditor); + ImageEditor *editor = qobject_cast(propertyEditor); editor->setImage(propertyValue().value()); } diff --git a/limereport/objectinspector/propertyItems/lrseriespropitem.cpp b/limereport/objectinspector/propertyItems/lrseriespropitem.cpp new file mode 100644 index 0000000..3e5b6eb --- /dev/null +++ b/limereport/objectinspector/propertyItems/lrseriespropitem.cpp @@ -0,0 +1,51 @@ +#include "lrseriespropitem.h" + +#include + +#include +#include +#include + +namespace{ +LimeReport::ObjectPropItem * createSeriesPropItem( + QObject *object, LimeReport::ObjectPropItem::ObjectsList* objects, const QString& name, const QString& displayName, const QVariant& data, LimeReport::ObjectPropItem* parent, bool readonly) +{ + return new LimeReport::SeriesPropItem(object, objects, name, displayName, data, parent, readonly); +} +bool VARIABLE_IS_NOT_USED registredSeriesProp = LimeReport::ObjectPropFactory::instance().registerCreator(LimeReport::APropIdent("series", "LimeReport::ChartItem"), QObject::tr("series"), createSeriesPropItem); +} + +namespace LimeReport { + +QWidget *SeriesPropItem::createProperyEditor(QWidget *parent) const +{ + return new SeriesPropEditor(qobject_cast(object()), parent); +} + +QString SeriesPropItem::displayValue() const +{ + return QObject::tr("Series"); +} + +SeriesPropEditor::SeriesPropEditor(ChartItem *chart, QWidget *parent) + : QWidget(parent), m_button(new QPushButton(this)), m_chart(chart) +{ + m_button->setText("..."); + QHBoxLayout* layout = new QHBoxLayout(this); + layout->addWidget(m_button); + layout->setSpacing(1); + layout->setContentsMargins(1,0,1,1); + setLayout(layout); + setFocusProxy(m_button); + setAutoFillBackground(true); + connect(m_button,SIGNAL(clicked()),this,SLOT(slotButtonClicked())); +} + +void SeriesPropEditor::slotButtonClicked() +{ + m_chart->showEditorDialog(); + emit editingFinished(); +} + + +} diff --git a/limereport/objectinspector/propertyItems/lrseriespropitem.h b/limereport/objectinspector/propertyItems/lrseriespropitem.h new file mode 100644 index 0000000..b7cdb1e --- /dev/null +++ b/limereport/objectinspector/propertyItems/lrseriespropitem.h @@ -0,0 +1,41 @@ +#ifndef SERIESPROPITEM_H +#define SERIESPROPITEM_H + +#include +#include +#include +#include + +namespace LimeReport { + +class SeriesPropEditor : public QWidget +{ + Q_OBJECT +public: + SeriesPropEditor(ChartItem* chart, QWidget *parent = 0); +signals: + void editingFinished(); +private slots: + void slotButtonClicked(); +private: + QPushButton* m_button; + ChartItem* m_chart; +}; + +class SeriesPropItem : public LimeReport::ObjectPropItem{ + Q_OBJECT +public: + SeriesPropItem():ObjectPropItem(){} + SeriesPropItem(QObject* object, ObjectsList* objects, const QString& name, const QString& displayName, const QVariant& value, ObjectPropItem* parent, bool readonly) + :ObjectPropItem(object, objects, name, displayName, value, parent, readonly){} + QWidget* createProperyEditor(QWidget *parent) const; + QString displayValue() const; +}; + +} // namespace LimeReport + + + + + +#endif // SERIESPROPITEM_H diff --git a/limereport/objectinspector/propertyItems/lrstringpropitem.cpp b/limereport/objectinspector/propertyItems/lrstringpropitem.cpp index 8c4c19a..b742c55 100644 --- a/limereport/objectinspector/propertyItems/lrstringpropitem.cpp +++ b/limereport/objectinspector/propertyItems/lrstringpropitem.cpp @@ -54,7 +54,7 @@ QWidget * StringPropItem::createProperyEditor(QWidget *parent) const void StringPropItem::setPropertyEditorData(QWidget *propertyEditor, const QModelIndex &) const { - ButtonLineEditor *editor =qobject_cast(propertyEditor); + ButtonLineEditor *editor = qobject_cast(propertyEditor); editor->setText(propertyValue().toString()); } From 36a7529b7658b9bdd32caeeecb29b1904d22617a Mon Sep 17 00:00:00 2001 From: Arin Alexander Date: Fri, 31 Jan 2020 20:01:11 +0300 Subject: [PATCH 3/3] Russian translation has been updated --- translations/limereport_ru.qm | Bin 124649 -> 124735 bytes translations/limereport_ru.ts | 16 ++++++++++++++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/translations/limereport_ru.qm b/translations/limereport_ru.qm index 3a14c7e8b2b1993263ea938faeb5d67aaaa60cc5..50b47c4aba22af41045a0de718b7f04dc7d66852 100644 GIT binary patch delta 6524 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 Series - Ряд + Ряды данных Add @@ -1952,7 +1952,7 @@ p, li { white-space: pre-wrap; } series - Ряд данных + Ряды данных titleAlign @@ -3225,5 +3225,17 @@ This preview is no longer valid. '' '' + + image + Изображение + + + series + Ряды данных + + + Series + Ряды данных +