From 4e6dd2d24c7c919d9a35ac07f82620402e1ea876 Mon Sep 17 00:00:00 2001 From: Max Chodorowski Date: Thu, 4 Jan 2024 22:11:04 +0000 Subject: [PATCH] Fixed sorting of decimal numbers separated by comma --- package.json | 2 +- src/sorting.ts | 6 ++++-- test/other/sorting.test.ts | 18 ++++++++++++++++++ 3 files changed, 23 insertions(+), 3 deletions(-) diff --git a/package.json b/package.json index c96a15c8..4d8f433b 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "battery-state-card", - "version": "3.1.0", + "version": "3.1.1", "description": "Battery State card for Home Assistant", "main": "dist/battery-state-card.js", "author": "Max Chodorowski", diff --git a/src/sorting.ts b/src/sorting.ts index 754280b3..93768543 100644 --- a/src/sorting.ts +++ b/src/sorting.ts @@ -25,8 +25,10 @@ import { isNumber, log, safeGetConfigArrayOfObjects } from "./utils"; valB = batteries[idB].name; break; case "state": - valA = batteries[idA].state; - valB = batteries[idB].state; + // not a perfect solution but we try to fix numer formatting in some countries/langs + // where decimals are separated by comma + valA = batteries[idA].state?.replace(",", "."); + valB = batteries[idB].state?.replace(",", "."); break; default: if ((o.by).startsWith("entity.")) { diff --git a/test/other/sorting.test.ts b/test/other/sorting.test.ts index b123bd3c..50eba194 100644 --- a/test/other/sorting.test.ts +++ b/test/other/sorting.test.ts @@ -78,6 +78,24 @@ describe("Entity sorting", () => { expect(sortedIds).toStrictEqual(expectedOrder); }); + + test.each([ + ["state", "38", "38,5", "38,4", ["a_sensor", "c_sensor", "b_sensor"]], + ["state", "38", "99,5", "99,4", ["a_sensor", "c_sensor", "b_sensor"]], + ["state", "38", "99,4", "99,44", ["a_sensor", "b_sensor", "c_sensor"]], + ["state", "38", "99.4", "99.44", ["a_sensor", "b_sensor", "c_sensor"]], + ])("Decimals separated by comma", (sort: string, stateA: string | undefined, stateB: string | undefined, stateC: string | undefined, expectedOrder: string[]) => { + + let testBatteries = [ + createBattery("a Sensor", stateA), + createBattery("b Sensor", stateB), + createBattery("c Sensor", stateC), + ]; + + const sortedIds = getIdsOfSortedBatteries({ entities: [], sort }, convertToCollection(testBatteries)); + + expect(sortedIds).toStrictEqual(expectedOrder); + }); }); const createBattery = (name: string, state: string | undefined, last_changed?: string | undefined) => {