From 6fb266f7cfa72bd174ede4e205ef3c7deee87f6b Mon Sep 17 00:00:00 2001 From: Tom Owers Date: Thu, 19 Dec 2024 12:20:31 +0100 Subject: [PATCH] fix(data-warehouse): Added types for tuples in data viz logic (#26950) --- .../DataVisualization/dataVisualizationLogic.ts | 13 +++++++++---- .../src/queries/nodes/DataVisualization/types.ts | 2 +- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/frontend/src/queries/nodes/DataVisualization/dataVisualizationLogic.ts b/frontend/src/queries/nodes/DataVisualization/dataVisualizationLogic.ts index 4480fe9977755..e2b0f57d11623 100644 --- a/frontend/src/queries/nodes/DataVisualization/dataVisualizationLogic.ts +++ b/frontend/src/queries/nodes/DataVisualization/dataVisualizationLogic.ts @@ -178,6 +178,9 @@ export const convertTableValue = ( } const toFriendlyClickhouseTypeName = (type: string): ColumnScalar => { + if (type.indexOf('Tuple') !== -1) { + return 'TUPLE' + } if (type.indexOf('Int') !== -1) { return 'INTEGER' } @@ -203,8 +206,8 @@ const toFriendlyClickhouseTypeName = (type: string): ColumnScalar => { return type as ColumnScalar } -const isNumericalType = (type: string): boolean => { - if (type.indexOf('Int') !== -1 || type.indexOf('Float') !== -1 || type.indexOf('Decimal') !== -1) { +const isNumericalType = (type: ColumnScalar): boolean => { + if (type === 'INTEGER' || type === 'FLOAT' || type === 'DECIMAL') { return true } @@ -547,11 +550,13 @@ export const dataVisualizationLogic = kea([ return columns.map((column, index) => { const type = types[index]?.[1] + const friendlyClickhouseTypeName = toFriendlyClickhouseTypeName(type) + return { name: column, type: { - name: toFriendlyClickhouseTypeName(type), - isNumerical: isNumericalType(type), + name: friendlyClickhouseTypeName, + isNumerical: isNumericalType(friendlyClickhouseTypeName), }, label: `${column} - ${type}`, dataIndex: index, diff --git a/frontend/src/queries/nodes/DataVisualization/types.ts b/frontend/src/queries/nodes/DataVisualization/types.ts index ad9f186f67001..b39a78b5658d2 100644 --- a/frontend/src/queries/nodes/DataVisualization/types.ts +++ b/frontend/src/queries/nodes/DataVisualization/types.ts @@ -1,4 +1,4 @@ -export type ColumnScalar = 'INTEGER' | 'FLOAT' | 'DATETIME' | 'DATE' | 'BOOLEAN' | 'DECIMAL' | 'STRING' +export type ColumnScalar = 'INTEGER' | 'FLOAT' | 'DATETIME' | 'DATE' | 'BOOLEAN' | 'DECIMAL' | 'STRING' | 'TUPLE' export interface FormattingTemplate { id: string