Merge partial Scattermind rank imports

This commit is contained in:
OpenClaw Bot
2026-05-26 23:30:35 +02:00
parent 36e8bfae58
commit 7151f0d378
3 changed files with 44 additions and 16 deletions
+8 -15
View File
@@ -496,12 +496,8 @@ function normalizeOptionIds(options = []) {
});
}
function candidateArrayFrom(...entries) {
return entries.find(entry => Array.isArray(entry?.items) && entry.items.length > 0) || null;
}
function candidateGroupFrom(...groups) {
return groups.find(group => group.some(entry => Array.isArray(entry?.items) && entry.items.length > 0)) || null;
function compactCandidateGroup(group = []) {
return group.filter(entry => Array.isArray(entry?.items) && entry.items.length > 0);
}
function normalizeCandidateGroup(group = []) {
@@ -515,7 +511,7 @@ function normalizeCandidateGroup(group = []) {
function optionsFromBody(body = {}) {
const featureSet = objectFrom(body.featureSet);
const conceptMap = objectFrom(body.conceptMap || featureSet.conceptMap);
const rawCandidates = candidateArrayFrom(
const directCandidateGroup = compactCandidateGroup([
{ items: body.features, sourceSection: 'features' },
{ items: featureSet.features, sourceSection: 'feature-set.features' },
{ items: body.actions, sourceSection: 'actions' },
@@ -523,13 +519,9 @@ function optionsFromBody(body = {}) {
{ items: body.nextMoves, sourceSection: 'nextMoves' },
{ items: featureSet.nextMoves, sourceSection: 'feature-set.nextMoves' },
{ items: body.candidates, sourceSection: 'candidates' },
{ items: featureSet.candidates, sourceSection: 'feature-set.candidates' }
);
if (rawCandidates) {
const fallbackId = rawCandidates.sourceSection.toLowerCase().includes('action') ? 'action' : 'feature';
return normalizeOptionIds(rawCandidates.items.slice(0, 24).map((item, index) => normalizeFeatureOption(item, index, fallbackId, rawCandidates.sourceSection)).filter(item => item.title));
}
const conceptMapCandidates = candidateGroupFrom([
{ items: featureSet.candidates, sourceSection: 'feature-set.candidates' },
]);
const conceptMapCandidateGroup = compactCandidateGroup([
{ items: conceptMap.nextActions, sourceSection: 'concept-map.nextActions' },
{ items: conceptMap.nextMoves, sourceSection: 'concept-map.nextMoves' },
{ items: conceptMap.features, sourceSection: 'concept-map.features' },
@@ -538,7 +530,8 @@ function optionsFromBody(body = {}) {
{ items: conceptMap.deferred || conceptMap.defer || conceptMap.later, sourceSection: 'concept-map.deferred', defaultLane: 'defer' },
{ items: conceptMap.parkingLot || conceptMap.park || conceptMap.parked, sourceSection: 'concept-map.parkingLot', defaultLane: 'park' },
]);
if (conceptMapCandidates) return normalizeCandidateGroup(conceptMapCandidates);
const groupedCandidates = [...directCandidateGroup, ...conceptMapCandidateGroup];
if (groupedCandidates.length) return normalizeCandidateGroup(groupedCandidates);
if (Array.isArray(body.options)) {
return normalizeOptionIds(body.options.slice(0, 24).map((item, index) => normalizeFeatureOption(item, index, 'option', 'options')).filter(item => item.title));
}