From c35f748bb658dc48796cc90d52790216999d66c9 Mon Sep 17 00:00:00 2001 From: Rohit Singh Date: Sun, 28 Jan 2024 20:42:46 +0530 Subject: [PATCH] Added formatting for Date columns --- example/custom-bar-chart/custom-chart.ts | 20 ++++++++++++++++++-- package.json | 1 + 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/example/custom-bar-chart/custom-chart.ts b/example/custom-bar-chart/custom-chart.ts index 17c4b93..2bb69ff 100644 --- a/example/custom-bar-chart/custom-chart.ts +++ b/example/custom-bar-chart/custom-chart.ts @@ -20,10 +20,12 @@ import { PointVal, Query, VisualProps, + DataType, } from '@thoughtspot/ts-chart-sdk'; import Chart from 'chart.js/auto'; import ChartDataLabels from 'chartjs-plugin-datalabels'; import _ from 'lodash'; +import moment from 'moment'; Chart.register(ChartDataLabels); @@ -37,9 +39,20 @@ const visualPropKeyMap = { 2: 'accordion.datalabels', }; +export const isDateColumn = (col) => + DataType[col.dataType] === 'DATE' || DataType[col.dataType] === 'DATE_TIME'; + function getDataForColumn(column: ChartColumn, dataArr: DataPointsArray) { const idx = _.findIndex(dataArr.columns, (colId) => column.id === colId); - return _.map(dataArr.dataValue, (row) => row[idx]); + return _.map(dataArr.dataValue, (row) => { + const colValue = row[idx]; + if(isDateColumn(column)) { + return moment(colValue).format(column.format?.pattern); + } + else { + return colValue; + } + }); } function getColumnDataModel( @@ -203,7 +216,10 @@ function render(ctx: CustomChartContext) { label: 'Custom user action 1', icon: '', onClick: (...arg) => { - console.log('custom action 1 triggered', arg); + console.log( + 'custom action 1 triggered', + arg, + ); }, }, { diff --git a/package.json b/package.json index e10a768..f86127d 100644 --- a/package.json +++ b/package.json @@ -74,6 +74,7 @@ }, "dependencies": { "lodash": "^4.17.21", + "moment": "2.29.4", "react": "^17.0.2", "react-dom": "^17.0.2" },