mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-27 14:20:52 +01:00
Improve element query widget
User can now filter each field of the query
This commit is contained in:
@@ -93,23 +93,48 @@ QVector<QStringList> projectDataBase::elementsInfoFromQuery(const QString &query
|
||||
QStringList projectDataBase::headersFromElementsInfoQuery(const QString &query)
|
||||
{
|
||||
QStringList header_string;
|
||||
if (query.startsWith("SELECT ") && query.contains("FROM"))
|
||||
{
|
||||
auto header = query;
|
||||
header.remove(0, 7); //Remove SELECT from the string;
|
||||
header.truncate(header.indexOf("FROM")); //Now we only have the string between SELECT and FROM
|
||||
header.replace(" ", ""); //remove white space
|
||||
QStringList list = header.split(",");
|
||||
if (!query.startsWith("SELECT ") && !query.contains("FROM")) {
|
||||
return header_string;
|
||||
}
|
||||
|
||||
if (!list.isEmpty())
|
||||
auto header = query;
|
||||
header.remove(0, 7); //Remove SELECT from the string;
|
||||
header.truncate(header.indexOf("FROM")); //Now we only have the string between SELECT and FROM
|
||||
header.replace(" ", ""); //remove white space
|
||||
QStringList list = header.split(","); //split each column
|
||||
|
||||
if (list.isEmpty()) {
|
||||
return header_string;
|
||||
}
|
||||
|
||||
for (int i=0 ; i<list.size() ; i++)
|
||||
{
|
||||
auto str = list.at(i);
|
||||
|
||||
if(str == "e.pos") { //Query in element table wich have only pose use in this case
|
||||
header_string.append(tr("Position"));
|
||||
}
|
||||
else if (str.contains("ei.")) //Query in element_info table
|
||||
{
|
||||
for (int i=0 ; i<list.size() ; i++)
|
||||
{
|
||||
if (list.at(i) == "pos") {
|
||||
header_string.append(tr("Position"));
|
||||
} else {
|
||||
header_string.append(QETApp::elementTranslatedInfoKey(list.at(i)));
|
||||
}
|
||||
str.remove(0,3);
|
||||
header_string.append(QETApp::elementTranslatedInfoKey(str));
|
||||
}
|
||||
else if (str == "d.pos") { //query in diagram table wich have only pos use in this case
|
||||
header_string.append(tr("Position du folio"));
|
||||
}
|
||||
else if (str.contains("di.")) //query in diagram_info table
|
||||
{
|
||||
str.remove(0,3);
|
||||
header_string.append(QETApp::diagramTranslatedInfoKey(str));
|
||||
}
|
||||
else //Default case
|
||||
{
|
||||
if (str == "pos") {
|
||||
header_string.append(tr("Position"));
|
||||
} else if (QETApp::elementInfoKeys().contains(str)) {
|
||||
header_string.append(QETApp::elementTranslatedInfoKey(str));
|
||||
} else {
|
||||
header_string.append(QETApp::diagramTranslatedInfoKey(str));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -29,11 +29,10 @@ ElementQueryWidget::ElementQueryWidget(QWidget *parent) :
|
||||
{
|
||||
ui->setupUi(this);
|
||||
|
||||
m_export_info.insert("pos", tr("Position"));
|
||||
// m_export_info.insert("folio_title", tr("Titre du folio"));
|
||||
// m_export_info.insert("folio_pos", tr("Position de folio"));
|
||||
// m_export_info.insert("folio_num", tr("Numéro de folio"));
|
||||
// m_export_info.insert("designation_qty", tr("Quantité (Numéro d'article)"));
|
||||
m_export_info.insert("e.pos", tr("Position"));
|
||||
m_export_info.insert("di.title", tr("Titre du folio"));
|
||||
m_export_info.insert("d.pos", tr("Position du folio"));
|
||||
m_export_info.insert("di.folio", tr("Numéro du folio"));
|
||||
|
||||
m_button_group.setExclusive(false);
|
||||
m_button_group.addButton(ui->m_all_cb, 0);
|
||||
@@ -110,6 +109,7 @@ QString ElementQueryWidget::queryStr() const
|
||||
|
||||
QString select ="SELECT ";
|
||||
QString order_by = " ORDER BY ";
|
||||
QString filter_;
|
||||
|
||||
QString column;
|
||||
bool first = true;
|
||||
@@ -122,35 +122,64 @@ QString ElementQueryWidget::queryStr() const
|
||||
}
|
||||
column += key;
|
||||
order_by += key;
|
||||
|
||||
auto f = FilterFor(key);
|
||||
switch (f.first)
|
||||
{
|
||||
case 0: //No filter
|
||||
break;
|
||||
case 1: //Not empty
|
||||
filter_ += QString(" AND ") += key += " IS NOT NULL";
|
||||
break;
|
||||
case 2: //empty
|
||||
filter_ += QString(" AND ") += key += " IS NULL";
|
||||
break;
|
||||
case 3: // contain
|
||||
filter_ += QString(" AND ") += key += QString(" LIKE'%") += f.second += "%'";
|
||||
break;
|
||||
case 4: // not contain
|
||||
filter_ += QString(" AND ") += key += QString(" NOT LIKE'%") += f.second += "%'";
|
||||
break;
|
||||
case 5: // is equal
|
||||
filter_ += QString(" AND ") += key += QString("='") += f.second += "'";
|
||||
break;
|
||||
case 6: // is not equal
|
||||
filter_ += QString(" AND ") += key += QString("!='") += f.second += "'";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
QString from = " FROM element_info";
|
||||
QString where;
|
||||
QString from = " FROM element_info ei, element e, diagram d, diagram_info di";
|
||||
QString where = " WHERE ei.element_uuid = e.uuid"
|
||||
" AND di.diagram_uuid = d.uuid"
|
||||
" AND e.diagram_uuid = d.uuid";
|
||||
|
||||
if (ui->m_all_cb->checkState() == Qt::PartiallyChecked)
|
||||
{
|
||||
if (ui->m_terminal_cb->isChecked()) {
|
||||
where = " WHERE element_type = 'Terminale'";
|
||||
}
|
||||
if (ui->m_simple_cb->isChecked()) {
|
||||
auto str = where.isEmpty() ? " WHERE element_type = 'Simple'" : " AND element_type = 'Simple'";
|
||||
where += str;
|
||||
}
|
||||
if (ui->m_button_cb->isChecked()) {
|
||||
auto str = where.isEmpty() ? " WHERE element_subtype = 'commutator'" : " AND element_subtype = 'commutator'";
|
||||
where += str;
|
||||
}
|
||||
if (ui->m_coil_cb->isChecked()) {
|
||||
auto str = where.isEmpty() ? " WHERE element_subtype = 'coil'" : " AND element_subtype = 'coil'";
|
||||
where += str;
|
||||
}
|
||||
if (ui->m_protection_cb->isChecked()) {
|
||||
auto str = where.isEmpty() ? " WHERE element_subtype = 'protection'" : " AND element_subtype = 'protection'";
|
||||
where += str;
|
||||
}
|
||||
if (ui->m_terminal_cb->isChecked()) {where += " AND e.type = 'Terminale'";}
|
||||
if (ui->m_simple_cb->isChecked()) {where += " AND e.type = 'Simple'";}
|
||||
if (ui->m_button_cb->isChecked()) {where += " AND e.sub_type = 'commutator'";}
|
||||
if (ui->m_coil_cb->isChecked()) {where += " AND e.sub_type = 'coil'";}
|
||||
if (ui->m_protection_cb->isChecked()) {where += " AND e.sub_type = 'protection'";}
|
||||
}
|
||||
|
||||
|
||||
QString q(select + column + from + where + filter_ + order_by);
|
||||
return q;
|
||||
}
|
||||
|
||||
QStringList ElementQueryWidget::header() const
|
||||
{
|
||||
//Made a string list with the colomns (keys) choosen by the user
|
||||
QStringList headers;
|
||||
int row = 0;
|
||||
while (auto *item = ui->m_choosen_list->item(row))
|
||||
{
|
||||
headers.append(item->data(Qt::DisplayRole).toString());
|
||||
++row;
|
||||
}
|
||||
|
||||
QString q(select + column + from + where + order_by);
|
||||
return q;
|
||||
return headers;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -183,10 +212,11 @@ void ElementQueryWidget::setUpItems()
|
||||
for(QString key : QETApp::elementInfoKeys())
|
||||
{
|
||||
auto item = new QListWidgetItem(QETApp::elementTranslatedInfoKey(key), ui->m_var_list);
|
||||
item->setData(Qt::UserRole, key);
|
||||
item->setData(Qt::UserRole, "ei." + key);
|
||||
m_items_list << item;
|
||||
}
|
||||
|
||||
|
||||
for (auto key : m_export_info.keys())
|
||||
{
|
||||
auto item = new QListWidgetItem(m_export_info.value(key), ui->m_var_list);
|
||||
@@ -195,6 +225,15 @@ void ElementQueryWidget::setUpItems()
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief ElementQueryWidget::FilterFor
|
||||
* @param key
|
||||
* @return the filter associated to key
|
||||
*/
|
||||
QPair<int, QString> ElementQueryWidget::FilterFor(const QString &key) const {
|
||||
return m_filter.value(key, qMakePair(0, QString()));
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief ElementQueryWidget::on_m_up_pb_clicked
|
||||
*/
|
||||
@@ -272,3 +311,54 @@ void ElementQueryWidget::on_m_edit_sql_query_cb_clicked()
|
||||
updateQueryLine();
|
||||
}
|
||||
}
|
||||
|
||||
void ElementQueryWidget::on_m_plant_textChanged(const QString &arg1) {
|
||||
Q_UNUSED(arg1)
|
||||
updateQueryLine();
|
||||
}
|
||||
|
||||
void ElementQueryWidget::on_m_location_textChanged(const QString &arg1) {
|
||||
Q_UNUSED(arg1)
|
||||
updateQueryLine();
|
||||
}
|
||||
|
||||
void ElementQueryWidget::on_m_filter_le_textEdited(const QString &arg1)
|
||||
{
|
||||
if (auto item = ui->m_choosen_list->currentItem())
|
||||
{
|
||||
auto key = item->data(Qt::UserRole).toString();
|
||||
auto type = ui->m_filter_type_cb->currentIndex();
|
||||
auto value = arg1;
|
||||
|
||||
m_filter.insert(key, qMakePair(type, value));
|
||||
updateQueryLine();
|
||||
}
|
||||
}
|
||||
|
||||
void ElementQueryWidget::on_m_filter_type_cb_activated(int index)
|
||||
{
|
||||
if (auto item = ui->m_choosen_list->currentItem())
|
||||
{
|
||||
auto key = item->data(Qt::UserRole).toString();
|
||||
auto type = index;
|
||||
auto value = ui->m_filter_le->text();
|
||||
|
||||
m_filter.insert(key, qMakePair(type, value));
|
||||
ui->m_filter_le->setDisabled(index <= 2);
|
||||
updateQueryLine();
|
||||
}
|
||||
}
|
||||
|
||||
void ElementQueryWidget::on_m_choosen_list_currentItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
|
||||
{
|
||||
Q_UNUSED(previous)
|
||||
|
||||
if (!current)
|
||||
return;
|
||||
|
||||
auto key = current->data(Qt::UserRole).toString();
|
||||
auto p = FilterFor(key);
|
||||
ui->m_filter_type_cb->setCurrentIndex(p.first);
|
||||
ui->m_filter_le->setText(p.second);
|
||||
ui->m_filter_le->setEnabled(p.first>=3);
|
||||
}
|
||||
|
||||
@@ -41,6 +41,7 @@ class ElementQueryWidget : public QWidget
|
||||
~ElementQueryWidget();
|
||||
|
||||
QString queryStr() const;
|
||||
QStringList header() const;
|
||||
|
||||
private slots:
|
||||
void on_m_up_pb_clicked();
|
||||
@@ -48,17 +49,25 @@ class ElementQueryWidget : public QWidget
|
||||
void on_m_remove_pb_clicked();
|
||||
void on_m_down_pb_clicked();
|
||||
void on_m_edit_sql_query_cb_clicked();
|
||||
void on_m_plant_textChanged(const QString &arg1);
|
||||
void on_m_location_textChanged(const QString &arg1);
|
||||
void on_m_filter_le_textEdited(const QString &arg1);
|
||||
void on_m_filter_type_cb_activated(int index);
|
||||
|
||||
void updateQueryLine();
|
||||
QStringList selectedKeys() const;
|
||||
void setUpItems();
|
||||
QPair<int, QString> FilterFor(const QString &key) const;
|
||||
|
||||
private:
|
||||
void on_m_choosen_list_currentItemChanged(QListWidgetItem *current, QListWidgetItem *previous);
|
||||
|
||||
private:
|
||||
Ui::ElementQueryWidget *ui;
|
||||
QHash <QString, QString> m_export_info;
|
||||
QButtonGroup m_button_group;
|
||||
QList <QListWidgetItem *> m_items_list;
|
||||
QString m_custom_query;
|
||||
QHash <QString, QPair<int, QString>> m_filter;
|
||||
};
|
||||
|
||||
#endif // ELEMENTQUERYWIDGET_H
|
||||
|
||||
@@ -7,7 +7,7 @@
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>341</width>
|
||||
<height>457</height>
|
||||
<height>527</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
@@ -163,6 +163,61 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QWidget" name="widget" native="true">
|
||||
<layout class="QGridLayout" name="gridLayout_3">
|
||||
<item row="1" column="1">
|
||||
<widget class="QComboBox" name="m_filter_type_cb">
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Pas de filtre</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>N'est pas vide</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Est vide</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Contient</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Ne contient pas</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Est égal à</string>
|
||||
</property>
|
||||
</item>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>N'est pas égale à</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QLineEdit" name="m_filter_le"/>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="label_4">
|
||||
<property name="text">
|
||||
<string>Filtre :</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item>
|
||||
<widget class="QWidget" name="m_parametre_widget" native="true">
|
||||
<layout class="QHBoxLayout" name="horizontalLayout_3">
|
||||
|
||||
Reference in New Issue
Block a user