Tweak GlCpuTemp widget to support other sensor units

The current code assumes all sensors report temperature, when in fact glances' sensor plugin also reports rpm (eg fan speeds) and percentages (eg batteries).

Changes:

 * Add support for percentages
 * Add support for rpm

Note: this widget should really be called something like `GlSensors`, but I haven't been able to easily find a way of renaming it without breaking people's existing configs and workflows.
This commit is contained in:
Luis Pabon 2023-04-03 17:02:18 +01:00
parent 9c90814dff
commit df5ada9340
1 changed files with 48 additions and 6 deletions

View File

@ -2,7 +2,7 @@
<div class="glances-temp-wrapper" v-if="tempData"> <div class="glances-temp-wrapper" v-if="tempData">
<div class="temp-row" v-for="sensor in tempData" :key="sensor.label"> <div class="temp-row" v-for="sensor in tempData" :key="sensor.label">
<p class="label">{{ sensor.label | formatLbl }}</p> <p class="label">{{ sensor.label | formatLbl }}</p>
<p :class="`temp range-${sensor.color}`">{{ sensor.value | formatVal }}</p> <p :class="`temp range-${sensor.color}`">{{ sensor.value | formatVal(sensor.sensorType) }}</p>
</div> </div>
</div> </div>
</template> </template>
@ -29,8 +29,15 @@ export default {
formatLbl(lbl) { formatLbl(lbl) {
return capitalize(lbl); return capitalize(lbl);
}, },
formatVal(val) { formatVal(val, sensorType) {
switch (sensorType) {
case 'rpm':
return `${Math.round(val)} rpm`;
case 'percentage':
return `${Math.round(val)}%`;
default:
return `${Math.round(val)}°C`; return `${Math.round(val)}°C`;
}
}, },
}, },
methods: { methods: {
@ -40,14 +47,49 @@ export default {
if (temp >= 75) return 'red'; if (temp >= 75) return 'red';
return 'grey'; return 'grey';
}, },
getPercentageColor(percentage) {
if (percentage < 20) return 'red';
if (percentage < 50) return 'orange';
if (percentage < 75) return 'yellow';
return 'green';
},
processData(sensorData) { processData(sensorData) {
const results = []; const results = [];
sensorData.forEach((sensor) => { sensorData.forEach((sensor) => {
const tempC = sensor.unit === 'F' ? fahrenheitToCelsius(sensor.value) : sensor.value; // Start by assuming the sensor's unit is degrees Celsius
let sensorValue = sensor.value;
let color = this.getTempColor(sensorValue);
let sensorType = 'temperature';
// Now, override above if sensor unit is actually of a different type
switch (sensor.unit) {
case 'F':
sensorValue = fahrenheitToCelsius(sensorValue);
color = fahrenheitToCelsius(sensorValue);
break;
// R is for RPM and is typically for fans
case 'R':
color = 'grey';
sensorType = 'rpm';
break;
// For instance, battery levels
case '%':
sensorType = 'percentage';
color = this.getPercentageColor(sensorValue);
break;
// Nothing to do here, already covered by default values
default:
break;
}
results.push({ results.push({
label: sensor.label, label: sensor.label,
value: tempC, value: sensorValue,
color: this.getTempColor(tempC), color,
sensorType,
}); });
}); });
this.tempData = results; this.tempData = results;