Skip to content

Commit

Permalink
getredash#4031 Counter visualization: formatting not applied to targe…
Browse files Browse the repository at this point in the history
…t value (getredash#4035)
  • Loading branch information
kravets-levko authored and arikfr committed Aug 4, 2019
1 parent 11cc274 commit 9eabf89
Show file tree
Hide file tree
Showing 4 changed files with 94 additions and 55 deletions.
7 changes: 3 additions & 4 deletions client/app/visualizations/counter/counter.html
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
<counter
ng-class="{'positive': targetValue && trendPositive, 'negative': targetValue && !trendPositive}"
ng-class="{'positive': showTrend && trendPositive, 'negative': showTrend && !trendPositive}"
resize-event="handleResize()"
>
<div ng-style="{
Expand All @@ -9,9 +9,8 @@
'-webkit-transform': 'scale(' + scale + ')',
'transform': 'scale(' + scale + ')'
}">
<value ng-if="isNumber">{{stringPrefix}}{{counterValue | number}}{{stringSuffix}}</value>
<value ng-if="!isNumber">{{stringPrefix}}{{counterValue}}{{stringSuffix}}</value>
<counter-target ng-if="targetValue" title="({{targetValue | number}})">({{targetValue | number}})</counter-target>
<value title="{{ counterValueTooltip }}">{{ counterValue }}</value>
<counter-target ng-if="targetValue" title="{{ targetValueTooltip }}">({{ targetValue }})</counter-target>
<counter-name>{{counterLabel}}</counter-name>
</div>
</counter>
92 changes: 71 additions & 21 deletions client/app/visualizations/counter/index.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import numberFormat from 'underscore.string/numberFormat';
import { isNumber } from 'lodash';
import { isNumber, toString } from 'lodash';
import numeral from 'numeral';
import { angular2react } from 'angular2react';
import { registerVisualization } from '@/visualizations';

Expand All @@ -14,8 +14,51 @@ const DEFAULT_OPTIONS = {
stringDecimal: 0,
stringDecChar: '.',
stringThouSep: ',',
tooltipFormat: '0,0.000', // TODO: Show in editor
};

// TODO: allow user to specify number format string instead of delimiters only
// It will allow to remove this function (move all that weird formatting logic to a migration
// that will set number format for all existing counter visualization)
function numberFormat(value, decimalPoints, decimalDelimiter, thousandsDelimiter) {
// Temporarily update locale data (restore defaults after formatting)
const locale = numeral.localeData();
const savedDelimiters = locale.delimiters;

// Mimic old behavior - AngularJS `number` filter defaults:
// - `,` as thousands delimiter
// - `.` as decimal delimiter
// - three decimal points
locale.delimiters = {
thousands: ',',
decimal: '.',
};
let formatString = '0,0.000';
if (
(Number.isFinite(decimalPoints) && (decimalPoints >= 0)) ||
decimalDelimiter ||
thousandsDelimiter
) {
locale.delimiters = {
thousands: thousandsDelimiter,
decimal: decimalDelimiter || '.',
};

formatString = '0,0';
if (decimalPoints > 0) {
formatString += '.';
while (decimalPoints > 0) {
formatString += '0';
decimalPoints -= 1;
}
}
}
const result = numeral(value).format(formatString);

locale.delimiters = savedDelimiters;
return result;
}

// TODO: Need to review this function, it does not properly handle edge cases.
function getRowNumber(index, size) {
if (index >= 0) {
Expand All @@ -29,6 +72,21 @@ function getRowNumber(index, size) {
return size + index;
}

function formatValue(value, { stringPrefix, stringSuffix, stringDecimal, stringDecChar, stringThouSep }) {
if (isNumber(value)) {
value = numberFormat(value, stringDecimal, stringDecChar, stringThouSep);
return toString(stringPrefix) + value + toString(stringSuffix);
}
return toString(value);
}

function formatTooltip(value, formatString) {
if (isNumber(value)) {
return numeral(value).format(formatString);
}
return toString(value);
}

const CounterRenderer = {
template: counterTemplate,
bindings: {
Expand Down Expand Up @@ -69,33 +127,25 @@ const CounterRenderer = {
} else if (counterColName) {
$scope.counterValue = data[rowNumber][counterColName];
}

$scope.showTrend = false;
if (targetColName) {
$scope.targetValue = data[targetRowNumber][targetColName];

if ($scope.targetValue) {
$scope.delta = $scope.counterValue - $scope.targetValue;
$scope.trendPositive = $scope.delta >= 0;
if (Number.isFinite($scope.counterValue) && Number.isFinite($scope.targetValue)) {
const delta = $scope.counterValue - $scope.targetValue;
$scope.showTrend = true;
$scope.trendPositive = delta >= 0;
}
} else {
$scope.targetValue = null;
}

$scope.isNumber = isNumber($scope.counterValue);
if ($scope.isNumber) {
$scope.stringPrefix = options.stringPrefix;
$scope.stringSuffix = options.stringSuffix;

const stringDecimal = options.stringDecimal;
const stringDecChar = options.stringDecChar;
const stringThouSep = options.stringThouSep;
if (stringDecimal || stringDecChar || stringThouSep) {
$scope.counterValue = numberFormat($scope.counterValue, stringDecimal, stringDecChar, stringThouSep);
$scope.isNumber = false;
}
} else {
$scope.stringPrefix = null;
$scope.stringSuffix = null;
}
$scope.counterValueTooltip = formatTooltip($scope.counterValue, options.tooltipFormat);
$scope.targetValueTooltip = formatTooltip($scope.targetValue, options.tooltipFormat);

$scope.counterValue = formatValue($scope.counterValue, options);
$scope.targetValue = formatValue($scope.targetValue, options);
}

$timeout(() => {
Expand Down
47 changes: 19 additions & 28 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 1 addition & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -83,8 +83,7 @@
"react-dom": "^16.8.3",
"react-grid-layout": "git+https://github.com/getredash/react-grid-layout.git",
"react2angular": "^3.2.1",
"ui-select": "^0.19.8",
"underscore.string": "^3.3.4"
"ui-select": "^0.19.8"
},
"devDependencies": {
"@babel/core": "^7.2.2",
Expand Down

0 comments on commit 9eabf89

Please sign in to comment.