mirror of
https://github.com/fralx/LimeReport.git
synced 2025-01-11 17:18:10 +03:00
Turn off translation for object properties ability has been added to the object inspector
This commit is contained in:
parent
9a3af52cd7
commit
99757097cc
17
include/lrpreparedpagesintf.h
Normal file
17
include/lrpreparedpagesintf.h
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#ifndef LRPREPAREDPAGESINTF_H
|
||||||
|
#define LRPREPAREDPAGESINTF_H
|
||||||
|
#include "lrglobal.h"
|
||||||
|
namespace LimeReport {
|
||||||
|
class LIMEREPORT_EXPORT IPreparedPages{
|
||||||
|
public:
|
||||||
|
virtual ~IPreparedPages(){};
|
||||||
|
virtual bool loadFromFile(const QString& fileName) = 0;
|
||||||
|
virtual bool loadFromString(const QString data) = 0;
|
||||||
|
virtual bool loadFromByteArray(QByteArray* data) = 0;
|
||||||
|
virtual bool saveToFile(const QString& fileName) = 0;
|
||||||
|
virtual QString saveToString() = 0;
|
||||||
|
virtual QByteArray saveToByteArray() = 0;
|
||||||
|
virtual void clear() = 0;
|
||||||
|
};
|
||||||
|
} //namespace LimeReport
|
||||||
|
#endif // LRPREPAREDPAGESINTF_H
|
@ -95,8 +95,6 @@ public:
|
|||||||
}
|
}
|
||||||
void setPageItem(PageItemDesignIntf* pageItem);
|
void setPageItem(PageItemDesignIntf* pageItem);
|
||||||
protected:
|
protected:
|
||||||
// void mouseMoveEvent(QMouseEvent *event);
|
|
||||||
// void resizeEvent(QResizeEvent *event);
|
|
||||||
bool viewportEvent(QEvent *event);
|
bool viewportEvent(QEvent *event);
|
||||||
private:
|
private:
|
||||||
PageItemDesignIntf* m_pageItem;
|
PageItemDesignIntf* m_pageItem;
|
||||||
|
@ -506,6 +506,7 @@ void ReportDesignWindow::createObjectInspector()
|
|||||||
m_validator = new ObjectNameValidator();
|
m_validator = new ObjectNameValidator();
|
||||||
m_objectInspector->setValidator(m_validator);
|
m_objectInspector->setValidator(m_validator);
|
||||||
m_objectInspector->setSubclassesAsLevel(false);
|
m_objectInspector->setSubclassesAsLevel(false);
|
||||||
|
m_objectInspector->setTranslateProperties(true);
|
||||||
m_objectInspector->setAlternatingRowColors(true);
|
m_objectInspector->setAlternatingRowColors(true);
|
||||||
m_objectInspector->setRootIsDecorated(!m_objectInspector->subclassesAsLevel());
|
m_objectInspector->setRootIsDecorated(!m_objectInspector->subclassesAsLevel());
|
||||||
QDockWidget *objectDoc = new QDockWidget(this);
|
QDockWidget *objectDoc = new QDockWidget(this);
|
||||||
@ -696,6 +697,7 @@ void ReportDesignWindow::writeState()
|
|||||||
settings()->setValue("ScriptEditorsState", m_editorsStates[ReportDesignWidget::Script]);
|
settings()->setValue("ScriptEditorsState", m_editorsStates[ReportDesignWidget::Script]);
|
||||||
settings()->setValue("TranslationEditorsState", m_editorsStates[ReportDesignWidget::Translations]);
|
settings()->setValue("TranslationEditorsState", m_editorsStates[ReportDesignWidget::Translations]);
|
||||||
settings()->setValue("InspectorFirsColumnWidth", m_objectInspector->columnWidth(0));
|
settings()->setValue("InspectorFirsColumnWidth", m_objectInspector->columnWidth(0));
|
||||||
|
settings()->setValue("InspectorTranslateProperties", m_objectInspector->translateProperties());
|
||||||
settings()->endGroup();
|
settings()->endGroup();
|
||||||
settings()->beginGroup("RecentFiles");
|
settings()->beginGroup("RecentFiles");
|
||||||
settings()->setValue("filesCount",m_recentFiles.count());
|
settings()->setValue("filesCount",m_recentFiles.count());
|
||||||
@ -811,6 +813,11 @@ void ReportDesignWindow::restoreSetting()
|
|||||||
m_objectInspector->setColumnWidth(0,v.toInt());
|
m_objectInspector->setColumnWidth(0,v.toInt());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
v = settings()->value("InspectorTranslateProperties");
|
||||||
|
if (v.isValid()){
|
||||||
|
m_objectInspector->setTranslateProperties(v.toBool());
|
||||||
|
}
|
||||||
|
|
||||||
settings()->endGroup();
|
settings()->endGroup();
|
||||||
|
|
||||||
settings()->beginGroup("RecentFiles");
|
settings()->beginGroup("RecentFiles");
|
||||||
|
@ -44,7 +44,7 @@ VariablesHolder::~VariablesHolder()
|
|||||||
QMap<QString,VarDesc*>::iterator it = m_varNames.begin();
|
QMap<QString,VarDesc*>::iterator it = m_varNames.begin();
|
||||||
while(it!=m_varNames.end()){
|
while(it!=m_varNames.end()){
|
||||||
delete *it;
|
delete *it;
|
||||||
it++;
|
++it;
|
||||||
}
|
}
|
||||||
m_varNames.clear();
|
m_varNames.clear();
|
||||||
m_userVariables.clear();
|
m_userVariables.clear();
|
||||||
|
BIN
limereport/objectinspector/images/settings.png
Normal file
BIN
limereport/objectinspector/images/settings.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 643 B |
@ -6,5 +6,6 @@
|
|||||||
<file>images/uncheck.png</file>
|
<file>images/uncheck.png</file>
|
||||||
<file alias="checked.png">images/check_w.png</file>
|
<file alias="checked.png">images/check_w.png</file>
|
||||||
<file alias="unchecked.png">images/uncheck_w.png</file>
|
<file alias="unchecked.png">images/uncheck_w.png</file>
|
||||||
|
<file>images/settings.png</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
@ -34,6 +34,7 @@
|
|||||||
#include <QHBoxLayout>
|
#include <QHBoxLayout>
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
#include <QToolButton>
|
#include <QToolButton>
|
||||||
|
#include <QMenu>
|
||||||
|
|
||||||
#include "lrglobal.h"
|
#include "lrglobal.h"
|
||||||
#include "lrobjectinspectorwidget.h"
|
#include "lrobjectinspectorwidget.h"
|
||||||
@ -183,10 +184,25 @@ ObjectInspectorWidget::ObjectInspectorWidget(QWidget *parent)
|
|||||||
connect(pbClear, SIGNAL(clicked()), le, SLOT(clear()));
|
connect(pbClear, SIGNAL(clicked()), le, SLOT(clear()));
|
||||||
le->setPlaceholderText(tr("Filter"));
|
le->setPlaceholderText(tr("Filter"));
|
||||||
connect(le, SIGNAL(textChanged(const QString&)), this, SLOT(slotFilterTextChanged(const QString&)));
|
connect(le, SIGNAL(textChanged(const QString&)), this, SLOT(slotFilterTextChanged(const QString&)));
|
||||||
|
|
||||||
|
QToolButton* settingButton = new QToolButton(this);
|
||||||
|
settingButton->setIcon(QIcon(":/items/images/settings.png"));
|
||||||
|
QMenu* settingMenu = new QMenu(settingButton);
|
||||||
|
m_translateProperties = settingMenu->addAction(tr("Translate properties"));
|
||||||
|
m_translateProperties->setCheckable(true);
|
||||||
|
m_translateProperties->setChecked(translateProperties());
|
||||||
|
|
||||||
|
connect(m_translateProperties, SIGNAL(toggled(bool)),
|
||||||
|
this, SLOT(slotTranslatePropertiesChecked(bool)));
|
||||||
|
|
||||||
|
settingButton->setMenu(settingMenu);
|
||||||
|
settingButton->setPopupMode(QToolButton::InstantPopup);
|
||||||
|
|
||||||
QHBoxLayout* h = new QHBoxLayout();
|
QHBoxLayout* h = new QHBoxLayout();
|
||||||
h->setSpacing(2);
|
h->setSpacing(2);
|
||||||
h->addWidget(le);
|
h->addWidget(le);
|
||||||
h->addWidget(pbClear);
|
h->addWidget(pbClear);
|
||||||
|
h->addWidget(settingButton);
|
||||||
l->addLayout(h);
|
l->addLayout(h);
|
||||||
l->addWidget(m_objectInspectorView);
|
l->addWidget(m_objectInspectorView);
|
||||||
l->setMargin(Const::DOCKWIDGET_MARGINS);
|
l->setMargin(Const::DOCKWIDGET_MARGINS);
|
||||||
@ -246,6 +262,18 @@ void ObjectInspectorWidget::setSubclassesAsLevel(bool value)
|
|||||||
m_propertyModel->setSubclassesAsLevel(value);
|
m_propertyModel->setSubclassesAsLevel(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ObjectInspectorWidget::translateProperties()
|
||||||
|
{
|
||||||
|
return m_propertyModel->isTranslateProperties();
|
||||||
|
}
|
||||||
|
|
||||||
|
void ObjectInspectorWidget::setTranslateProperties(bool value)
|
||||||
|
{
|
||||||
|
m_propertyModel->setTranslateProperties(value);
|
||||||
|
m_translateProperties->setChecked(value);
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
||||||
const QObject *ObjectInspectorWidget::object(){
|
const QObject *ObjectInspectorWidget::object(){
|
||||||
return m_propertyModel->currentObject();
|
return m_propertyModel->currentObject();
|
||||||
}
|
}
|
||||||
@ -276,4 +304,9 @@ void ObjectInspectorWidget::slotFilterTextChanged(const QString &filter)
|
|||||||
m_filterModel->setFilterRegExp(QRegExp(filter, Qt::CaseInsensitive, QRegExp::FixedString));
|
m_filterModel->setFilterRegExp(QRegExp(filter, Qt::CaseInsensitive, QRegExp::FixedString));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ObjectInspectorWidget::slotTranslatePropertiesChecked(bool value)
|
||||||
|
{
|
||||||
|
setTranslateProperties(value);
|
||||||
|
}
|
||||||
|
|
||||||
} //namespace LimeReport
|
} //namespace LimeReport
|
||||||
|
@ -83,6 +83,8 @@ public:
|
|||||||
void setValidator(ValidatorIntf *validator);
|
void setValidator(ValidatorIntf *validator);
|
||||||
bool subclassesAsLevel();
|
bool subclassesAsLevel();
|
||||||
void setSubclassesAsLevel(bool value);
|
void setSubclassesAsLevel(bool value);
|
||||||
|
bool translateProperties();
|
||||||
|
void setTranslateProperties(bool value);
|
||||||
void setObject(QObject* setObject);
|
void setObject(QObject* setObject);
|
||||||
const QObject* object();
|
const QObject* object();
|
||||||
void setMultiObjects(QList<QObject *>* list);
|
void setMultiObjects(QList<QObject *>* list);
|
||||||
@ -90,10 +92,13 @@ public:
|
|||||||
void updateProperty(const QString &propertyName);
|
void updateProperty(const QString &propertyName);
|
||||||
private slots:
|
private slots:
|
||||||
void slotFilterTextChanged(const QString& filter);
|
void slotFilterTextChanged(const QString& filter);
|
||||||
|
void slotTranslatePropertiesChecked(bool value);
|
||||||
private:
|
private:
|
||||||
ObjectInspectorTreeView* m_objectInspectorView;
|
ObjectInspectorTreeView* m_objectInspectorView;
|
||||||
QSortFilterProxyModel* m_filterModel;
|
QSortFilterProxyModel* m_filterModel;
|
||||||
BaseDesignPropertyModel* m_propertyModel;
|
BaseDesignPropertyModel* m_propertyModel;
|
||||||
|
QAction* m_translateProperties;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} //namespace LimeReport
|
} //namespace LimeReport
|
||||||
|
@ -169,7 +169,8 @@ void QObjectPropertyModel::clearObjectsList()
|
|||||||
}
|
}
|
||||||
|
|
||||||
QObjectPropertyModel::QObjectPropertyModel(QObject *parent/*=0*/)
|
QObjectPropertyModel::QObjectPropertyModel(QObject *parent/*=0*/)
|
||||||
:QAbstractItemModel(parent),m_rootNode(0),m_object(0),m_dataChanging(false), m_subclassesAsLevel(true), m_validator(0)
|
:QAbstractItemModel(parent),m_rootNode(0), m_object(0), m_dataChanging(false),
|
||||||
|
m_subclassesAsLevel(true), m_validator(0), m_translateProperties(true)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
QObjectPropertyModel::~QObjectPropertyModel()
|
QObjectPropertyModel::~QObjectPropertyModel()
|
||||||
@ -297,16 +298,17 @@ QVariant QObjectPropertyModel::data(const QModelIndex &index, int role) const
|
|||||||
switch (role) {
|
switch (role) {
|
||||||
case Qt::DisplayRole:
|
case Qt::DisplayRole:
|
||||||
if (!node) return QVariant();
|
if (!node) return QVariant();
|
||||||
|
node->setTranslateProperty(isTranslateProperties());
|
||||||
if (index.column()==0){
|
if (index.column()==0){
|
||||||
return node->displayName();
|
return node->displayName();
|
||||||
} else return node->displayValue();
|
} else {
|
||||||
break;
|
return node->displayValue();
|
||||||
|
}
|
||||||
case Qt::DecorationRole :
|
case Qt::DecorationRole :
|
||||||
if (!node) return QIcon();
|
if (!node) return QIcon();
|
||||||
if (index.column()==1){
|
if (index.column()==1){
|
||||||
return node->iconValue();
|
return node->iconValue();
|
||||||
} else return QIcon();
|
} else return QIcon();
|
||||||
break;
|
|
||||||
case Qt::UserRole:
|
case Qt::UserRole:
|
||||||
return QVariant::fromValue(node);
|
return QVariant::fromValue(node);
|
||||||
default:
|
default:
|
||||||
@ -418,6 +420,16 @@ ObjectPropItem * QObjectPropertyModel::createPropertyItem(QMetaProperty prop, QO
|
|||||||
}
|
}
|
||||||
return propertyItem;
|
return propertyItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool QObjectPropertyModel::isTranslateProperties() const
|
||||||
|
{
|
||||||
|
return m_translateProperties;
|
||||||
|
}
|
||||||
|
|
||||||
|
void QObjectPropertyModel::setTranslateProperties(bool translateProperties)
|
||||||
|
{
|
||||||
|
m_translateProperties = translateProperties;
|
||||||
|
}
|
||||||
ValidatorIntf *QObjectPropertyModel::validator() const
|
ValidatorIntf *QObjectPropertyModel::validator() const
|
||||||
{
|
{
|
||||||
return m_validator;
|
return m_validator;
|
||||||
|
@ -72,6 +72,9 @@ public:
|
|||||||
void setValidator(ValidatorIntf* validator);
|
void setValidator(ValidatorIntf* validator);
|
||||||
void translatePropertyName();
|
void translatePropertyName();
|
||||||
void clearObjectsList();
|
void clearObjectsList();
|
||||||
|
bool isTranslateProperties() const;
|
||||||
|
void setTranslateProperties(bool isTranslateProperties);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void objectPropetyChanged(const QString& , const QVariant&, const QVariant&);
|
void objectPropetyChanged(const QString& , const QVariant&, const QVariant&);
|
||||||
private slots:
|
private slots:
|
||||||
@ -89,6 +92,7 @@ private:
|
|||||||
bool m_dataChanging;
|
bool m_dataChanging;
|
||||||
bool m_subclassesAsLevel;
|
bool m_subclassesAsLevel;
|
||||||
ValidatorIntf* m_validator;
|
ValidatorIntf* m_validator;
|
||||||
|
bool m_translateProperties;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,8 @@ bool lesThen(ObjectPropItem* v1, ObjectPropItem* v2){
|
|||||||
|
|
||||||
ObjectPropItem::ObjectPropItem(QObject *object, ObjectsList* objects, const QString &name, const QString &displayName, ObjectPropItem *parent, bool isClass)
|
ObjectPropItem::ObjectPropItem(QObject *object, ObjectsList* objects, const QString &name, const QString &displayName, ObjectPropItem *parent, bool isClass)
|
||||||
:m_object(object), m_name(name), m_displayName(displayName), m_haveValue(false), m_parent(parent), m_colorIndex(-1),
|
:m_object(object), m_name(name), m_displayName(displayName), m_haveValue(false), m_parent(parent), m_colorIndex(-1),
|
||||||
m_readonly(true), m_model(0), m_isClass(isClass), m_changingValue(false)
|
m_readonly(true), m_model(0), m_isClass(isClass), m_changingValue(false),
|
||||||
|
m_translatePropperty(true)
|
||||||
{
|
{
|
||||||
if (parent) setModel(parent->model());
|
if (parent) setModel(parent->model());
|
||||||
m_index=QModelIndex();
|
m_index=QModelIndex();
|
||||||
@ -60,7 +61,8 @@ ObjectPropItem::ObjectPropItem(QObject *object, ObjectsList* objects, const QStr
|
|||||||
ObjectPropItem::ObjectPropItem(QObject *object, ObjectsList* objects, const QString &name, const QString &displayName, const QVariant &value, ObjectPropItem *parent, bool readonly)
|
ObjectPropItem::ObjectPropItem(QObject *object, ObjectsList* objects, const QString &name, const QString &displayName, const QVariant &value, ObjectPropItem *parent, bool readonly)
|
||||||
:m_object(object), m_name(name), m_displayName(displayName), m_value(value),
|
:m_object(object), m_name(name), m_displayName(displayName), m_value(value),
|
||||||
m_haveValue(true), m_parent(parent), m_colorIndex(-1),
|
m_haveValue(true), m_parent(parent), m_colorIndex(-1),
|
||||||
m_readonly(readonly), m_model(0), m_isClass(false), m_changingValue(false)
|
m_readonly(readonly), m_model(0), m_isClass(false), m_changingValue(false),
|
||||||
|
m_translatePropperty(true)
|
||||||
{
|
{
|
||||||
if (parent) setModel(parent->model());
|
if (parent) setModel(parent->model());
|
||||||
m_index=QModelIndex();
|
m_index=QModelIndex();
|
||||||
@ -109,6 +111,10 @@ void ObjectPropItem::setPropertyValue(QVariant value){
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString ObjectPropItem::displayName() const {
|
||||||
|
return isTranslateProperty() ? m_displayName : propertyName();
|
||||||
|
}
|
||||||
|
|
||||||
int ObjectPropItem::row(){
|
int ObjectPropItem::row(){
|
||||||
if (m_parent)
|
if (m_parent)
|
||||||
return m_parent->m_childItems.indexOf(const_cast<ObjectPropItem*>(this));
|
return m_parent->m_childItems.indexOf(const_cast<ObjectPropItem*>(this));
|
||||||
@ -155,6 +161,16 @@ void ObjectPropItem::setValueToObject(const QString &propertyName, QVariant prop
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool ObjectPropItem::isTranslateProperty() const
|
||||||
|
{
|
||||||
|
return m_translatePropperty;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ObjectPropItem::setTranslateProperty(bool translatePropperty)
|
||||||
|
{
|
||||||
|
m_translatePropperty = translatePropperty;
|
||||||
|
}
|
||||||
|
|
||||||
ObjectPropItem * ObjectPropItem::findChild(const QString &name)
|
ObjectPropItem * ObjectPropItem::findChild(const QString &name)
|
||||||
{
|
{
|
||||||
foreach(ObjectPropItem* item,m_childItems){
|
foreach(ObjectPropItem* item,m_childItems){
|
||||||
|
@ -56,7 +56,7 @@ namespace LimeReport{
|
|||||||
virtual QVariant propertyValue() const;
|
virtual QVariant propertyValue() const;
|
||||||
virtual void setPropertyValue(QVariant value);
|
virtual void setPropertyValue(QVariant value);
|
||||||
virtual QString propertyName() const {return m_name;}
|
virtual QString propertyName() const {return m_name;}
|
||||||
virtual QString displayName() const {return m_displayName;}
|
virtual QString displayName() const;
|
||||||
virtual QString displayValue() const;
|
virtual QString displayValue() const;
|
||||||
virtual QIcon iconValue() const{return QIcon();}
|
virtual QIcon iconValue() const{return QIcon();}
|
||||||
virtual bool isHaveChildren() const {return m_childItems.count()>0;}
|
virtual bool isHaveChildren() const {return m_childItems.count()>0;}
|
||||||
@ -90,6 +90,8 @@ namespace LimeReport{
|
|||||||
void setModelIndex(const QModelIndex& index){m_index=index;}
|
void setModelIndex(const QModelIndex& index){m_index=index;}
|
||||||
QModelIndex modelIndex(){return m_index;}
|
QModelIndex modelIndex(){return m_index;}
|
||||||
bool isClass(){return m_isClass;}
|
bool isClass(){return m_isClass;}
|
||||||
|
bool isTranslateProperty() const;
|
||||||
|
void setTranslateProperty(bool translatePropperty);
|
||||||
#ifdef INSPECT_BASEDESIGN
|
#ifdef INSPECT_BASEDESIGN
|
||||||
private slots:
|
private slots:
|
||||||
void slotPropertyChanged(const QString& name, QVariant, QVariant newValue);
|
void slotPropertyChanged(const QString& name, QVariant, QVariant newValue);
|
||||||
@ -120,6 +122,7 @@ namespace LimeReport{
|
|||||||
QModelIndex m_index;
|
QModelIndex m_index;
|
||||||
bool m_isClass;
|
bool m_isClass;
|
||||||
bool m_changingValue;
|
bool m_changingValue;
|
||||||
|
bool m_translatePropperty;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef QPair<QString,QString> APropIdent;
|
typedef QPair<QString,QString> APropIdent;
|
||||||
|
@ -162,7 +162,7 @@ void EnumPropItem::setModelData(QWidget *propertyEditor, QAbstractItemModel *mod
|
|||||||
QString EnumPropItem::nameByType(int value) const
|
QString EnumPropItem::nameByType(int value) const
|
||||||
{
|
{
|
||||||
QMetaEnum propEnum = object()->metaObject()->property(object()->metaObject()->indexOfProperty(propertyName().toLatin1())).enumerator();
|
QMetaEnum propEnum = object()->metaObject()->property(object()->metaObject()->indexOfProperty(propertyName().toLatin1())).enumerator();
|
||||||
return tr(propEnum.valueToKey(value));
|
return isTranslateProperty() ? tr(propEnum.valueToKey(value)) : propEnum.valueToKey(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
int EnumPropItem::typeByName(const QString &value) const
|
int EnumPropItem::typeByName(const QString &value) const
|
||||||
|
@ -97,8 +97,8 @@ QString FlagsPropItem::displayValue() const
|
|||||||
{
|
{
|
||||||
if ((propEnum.keyToValue(propEnum.key(i)) == 0) ? propertyValue().toInt() == 0 : (propertyValue().toInt() & propEnum.keyToValue(propEnum.key(i))) == propEnum.keyToValue(propEnum.key(i)))
|
if ((propEnum.keyToValue(propEnum.key(i)) == 0) ? propertyValue().toInt() == 0 : (propertyValue().toInt() & propEnum.keyToValue(propEnum.key(i))) == propEnum.keyToValue(propEnum.key(i)))
|
||||||
{
|
{
|
||||||
if (result.isEmpty()) result+= tr(propEnum.key(i));
|
if (result.isEmpty()) result+= isTranslateProperty() ? tr(propEnum.key(i)) : propEnum.key(i);
|
||||||
else result=result+" | "+tr(propEnum.key(i));
|
else result=result+" | "+ (isTranslateProperty() ? tr(propEnum.key(i)) : propEnum.key(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Binary file not shown.
@ -1235,6 +1235,10 @@ p, li { white-space: pre-wrap; }
|
|||||||
<source>Filter</source>
|
<source>Filter</source>
|
||||||
<translation>Фильтр</translation>
|
<translation>Фильтр</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>Translate properties</source>
|
||||||
|
<translation>Переводить имена свойств</translation>
|
||||||
|
</message>
|
||||||
</context>
|
</context>
|
||||||
<context>
|
<context>
|
||||||
<name>LimeReport::PDFExporter</name>
|
<name>LimeReport::PDFExporter</name>
|
||||||
|
Loading…
Reference in New Issue
Block a user