From 6e699a163d696ef251afc21b60730ae4a6388714 Mon Sep 17 00:00:00 2001 From: mike12345567 Date: Tue, 9 Jul 2024 16:32:35 +0100 Subject: [PATCH] Cleaning up how junction fields are added to query. --- .../server/src/sdk/app/rows/search/sqs.ts | 20 ++++++++----------- 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/packages/server/src/sdk/app/rows/search/sqs.ts b/packages/server/src/sdk/app/rows/search/sqs.ts index b7af8705a2..4745aee7fb 100644 --- a/packages/server/src/sdk/app/rows/search/sqs.ts +++ b/packages/server/src/sdk/app/rows/search/sqs.ts @@ -59,6 +59,13 @@ function buildInternalFieldList( opts?: { relationships?: RelationshipsJson[] } ) { let fieldList: string[] = [] + const addJunctionFields = (relatedTable: Table, fields: string[]) => { + fields.forEach(field => { + fieldList.push( + `${generateJunctionTableID(table._id!, relatedTable._id!)}.${field}` + ) + }) + } fieldList = fieldList.concat( CONSTANT_INTERNAL_ROW_COLS.map(col => `${table._id}.${col}`) ) @@ -72,18 +79,7 @@ function buildInternalFieldList( const relatedTable = tables.find(table => table._id === linkCol.tableId)! // no relationships provided, don't go more than a layer deep fieldList = fieldList.concat(buildInternalFieldList(relatedTable, tables)) - fieldList.push( - `${generateJunctionTableID( - table._id!, - relatedTable._id! - )}.doc1.fieldName` - ) - fieldList.push( - `${generateJunctionTableID( - table._id!, - relatedTable._id! - )}.doc2.fieldName` - ) + addJunctionFields(relatedTable, ["doc1.fieldName", "doc2.fieldName"]) } else { fieldList.push(`${table._id}.${mapToUserColumn(col.name)}`) }