From 2d5d07c3f819f1a932d566cd0354b9c9827d50fc Mon Sep 17 00:00:00 2001 From: Giovanna Dagel <50461522+gidagel@users.noreply.github.com> Date: Thu, 30 Sep 2021 19:18:05 +0100 Subject: [PATCH] Speed now with better sizing (#46) --- package.json | 2 +- src/components/Speed.js | 52 +++++++++++++++------------- src/components/charts/Speedometer.js | 38 ++++++-------------- 3 files changed, 40 insertions(+), 52 deletions(-) diff --git a/package.json b/package.json index 5bdb1c6..5360411 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@vela/ui", - "version": "0.6.29", + "version": "0.6.30", "description": "Vela React UI Toolkit", "main": "src/index.js", "scripts": { diff --git a/src/components/Speed.js b/src/components/Speed.js index 4a0015a..59c86e4 100644 --- a/src/components/Speed.js +++ b/src/components/Speed.js @@ -1,36 +1,40 @@ -import React, {useState, useEffect} from 'react' -import Text from './Text' -import Heading from './Typography/Heading' -import Paragraph from './Typography/Paragraph' -import convert from 'convert-units' -import {useSystem} from '../lib/useSystem' +import React, { useState, useEffect } from "react"; +import Text from "./Text"; +import Heading from "./Typography/Heading"; +import Paragraph from "./Typography/Paragraph"; +import convert from "convert-units"; +import { useSystem } from "../lib/useSystem"; -function Speed({ - speed, - size, - ...props -}) { - const system = useSystem() - const unit = system === 'metric' ? 'km/h' : 'm/h' - const displayUnit = unit === 'm/h' ? 'mi/h' : unit +function Speed({ speed, size, ...props }) { + const system = useSystem(); + const unit = system === "metric" ? "km/h" : "m/h"; + const displayUnit = unit === "m/h" ? "mi/h" : unit; - const [instantSpeed, setInstantSpeed] = useState(0) + const speedStyle = { + lineHeight: 56, + }; + + const [instantSpeed, setInstantSpeed] = useState(0); useEffect(() => { const interval = setInterval(() => { - if (instantSpeed > speed) setInstantSpeed(instantSpeed - 1) - if (instantSpeed < speed) setInstantSpeed(instantSpeed + 1) - }, 100) - return () => clearInterval(interval) - }) + if (instantSpeed > speed) setInstantSpeed(instantSpeed - 1); + if (instantSpeed < speed) setInstantSpeed(instantSpeed + 1); + }, 100); + return () => clearInterval(interval); + }); - const value = convert(instantSpeed).from('km/h').to(unit) + const value = convert(instantSpeed) + .from("km/h") + .to(unit); return ( <> - {value.toFixed(0)} + + {value.toFixed(0)} + {displayUnit} - ) + ); } -export default Speed +export default Speed; diff --git a/src/components/charts/Speedometer.js b/src/components/charts/Speedometer.js index aa71672..c244293 100644 --- a/src/components/charts/Speedometer.js +++ b/src/components/charts/Speedometer.js @@ -1,37 +1,21 @@ -import React from 'react' -import {View} from 'react-native' +import React from "react"; +import { View } from "react-native"; -import Speed from '../Speed' +import Speed from "../Speed"; const containerStyle = { - width: 96, + justifyContent: "space-between", + alignItems: "center", height: 96, - justifyContent: 'space-between', - alignItems: 'center', - overflow: 'hidden', - backgroundColor: 'transparent' -} - -const viewStyle = { - position: 'absolute', - left: -5 -} - -export default function Speedometer({speed = 0, size}) { - - const textStyle = { - textAlign: 'center' - } +}; +export default function Speedometer({ speed = 0, size }) { return ( <> - - {/* */} - - + + {/* */} + + ); }