fix(ui): 类型筛选改用组内数据自带类型值(typeName/dsTypeCode),不再依赖缺失的arrayType

按用户口径:类型筛选=按加载到该段的数据其自身携带的类型值的范围筛选。装置/arrayType 实测不在
ds 行数据上(data/page 不返回),故改用 ds 已带的 typeName(多为中文)作筛选维度,缺失回退 dsTypeCode
(必要时全局枚举翻译)。下拉列出组内实际出现的类型;passesFilters 按 typeName/dsTypeCode 比对。

构建:app 链接通过
This commit is contained in:
gaozheng 2026-06-25 22:09:15 +08:00
parent 31ad7a4750
commit 2f6ec7dae2
1 changed files with 21 additions and 23 deletions

View File

@ -156,40 +156,38 @@ void CategorySection::refreshArrayCombo() {
const QSignalBlocker block(arrayCombo_); const QSignalBlocker block(arrayCombo_);
arrayCombo_->clear(); arrayCombo_->clear();
arrayCombo_->addItem(QStringLiteral("全部装置"), QString()); arrayCombo_->addItem(QStringLiteral("全部装置"), QString());
if (dict_) { // 按「加载到本段的数据自身携带的类型值」的范围筛选(用户口径)。装置/arrayType 不在 ds 行数据上
const auto& en = dict_->arrayTypeEnum(); // 全局装置枚举 itemValue→中文 // (实测 data/page 列表无该字段),故用 ds 已带的类型名 typeName多为中文作筛选维度
QSet<QString> seen; // typeName 缺失时回退 dsTypeCode + 全局枚举翻译。列出组内出现过的类型值。
// 列出当前数据里出现过的装置值 → 中文名。兼容 ds 把装置存成 itemValue(键) 或中文名(值) 两种形态。 QSet<QString> seen;
for (const auto& r : rows_) { for (const auto& r : rows_) {
for (const auto& kv : r.properties) { QString display = QString::fromStdString(r.typeName);
const QString val = QString::fromStdString(kv.value); QString code = display;
QString name; if (display.isEmpty() && !r.dsTypeCode.empty()) { // 无类型名 → 用 dsTypeCode必要时枚举翻译
const auto it = en.find(kv.value); code = QString::fromStdString(r.dsTypeCode);
if (it != en.end()) { display = code;
name = QString::fromStdString(it->second); // value 是 itemValue → 取中文名 if (dict_) {
} else { const auto& en = dict_->arrayTypeEnum();
for (const auto& e : en) // value 可能直接是中文名 const auto it = en.find(r.dsTypeCode);
if (QString::fromStdString(e.second) == val) { name = val; break; } if (it != en.end()) display = QString::fromStdString(it->second);
}
if (name.isEmpty() || seen.contains(val)) continue;
seen.insert(val);
arrayCombo_->addItem(name, val); // data=实际属性值passesFilters 据此比对)
} }
} }
if (code.isEmpty() || seen.contains(code)) continue;
seen.insert(code);
arrayCombo_->addItem(display, code); // itemData=类型值passesFilters 据此比对 typeName/dsTypeCode
} }
const int idx = arrayCombo_->findData(prev); // 尽量保留上次选择 const int idx = arrayCombo_->findData(prev); // 尽量保留上次选择
arrayCombo_->setCurrentIndex(idx >= 0 ? idx : 0); arrayCombo_->setCurrentIndex(idx >= 0 ? idx : 0);
} }
bool CategorySection::passesFilters(const DsRow& row) const { bool CategorySection::passesFilters(const DsRow& row) const {
// 装置类型筛选(全局枚举;"全部"=空不筛ds.properties 任一 value 命中选中 itemValue // 类型筛选("全部"=空不筛):按 ds 自身类型值typeName回退 dsTypeCode命中选中项
if (spec_.hasArrayTypeFilter && arrayCombo_) { if (spec_.hasArrayTypeFilter && arrayCombo_) {
const QString sel = arrayCombo_->currentData().toString(); const QString sel = arrayCombo_->currentData().toString();
if (!sel.isEmpty()) { if (!sel.isEmpty()) {
bool hit = false; const QString t = !row.typeName.empty() ? QString::fromStdString(row.typeName)
for (const auto& kv : row.properties) : QString::fromStdString(row.dsTypeCode);
if (QString::fromStdString(kv.value) == sel) { hit = true; break; } if (t != sel) return false;
if (!hit) return false;
} }
} }
// 采集时间范围collectTime 经 dict 取;缺则回退 createTime空范围不约束 // 采集时间范围collectTime 经 dict 取;缺则回退 createTime空范围不约束