Skip to content

Commit

Permalink
Mini-widgets: Very-generic-indicator: Add decimal places and width co…
Browse files Browse the repository at this point in the history
…nfigs

Signed-off-by: Arturo Manzoli <[email protected]>
  • Loading branch information
ArturoManzoli committed Oct 30, 2024
1 parent 6ac295c commit aeb6be4
Showing 1 changed file with 58 additions and 5 deletions.
63 changes: 58 additions & 5 deletions src/components/mini-widgets/VeryGenericIndicator.vue
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
<template>
<div class="h-12 p-1 text-white transition-all w-[8.5rem] relative scroll-container">
<div
class="h-12 p-1 min-w-[8.5rem] text-white transition-all relative scroll-container"
:class="{
'border-[1px] border-dashed border-[#FFFFFF55]': widgetStore.miniWidgetManagerVars(miniWidget.hash)
.configMenuOpen,
}"
:style="{ width: miniWidget.options.widgetWidth + 'px' }"
>
<span class="h-full left-[0.5rem] bottom-[5%] absolute mdi text-[2.25rem]" :class="[miniWidget.options.iconName]" />
<div class="absolute left-[3rem] h-full select-none font-semibold scroll-container w-[5.5rem]">
<div class="w-full" :class="{ 'scroll-text': valueIsOverflowing }">
Expand Down Expand Up @@ -38,9 +45,19 @@
</v-card-title>

<div v-if="currentTab === 'custom'" class="flex flex-col items-center justify-around">
<div class="flex flex-col items-center justify-between w-full mt-3">
<span class="w-full mb-1 text-sm text-slate-100/50">Display name</span>
<input v-model="miniWidget.options.displayName" class="w-full px-2 py-1 rounded-md bg-[#FFFFFF12]" />
<div class="flex w-full gap-x-10">
<div class="flex flex-col items-center justify-between w-3/4 mt-3">
<span class="w-full mb-1 text-sm text-slate-100/50">Display name</span>
<input v-model="miniWidget.options.displayName" class="w-full px-2 py-1 rounded-md bg-[#FFFFFF12]" />
</div>
<div class="flex flex-col items-center justify-between w-1/4 mt-3">
<span class="w-full text-sm text-slate-100/50">Display Width</span>
<input
v-model="miniWidget.options.widgetWidth"
type="number"
class="w-full px-2 py-1 rounded-md bg-[#FFFFFF12]"
/>
</div>
</div>
<div class="flex flex-col items-center justify-between w-full mt-3">
<span class="w-full mb-1 text-sm text-slate-100/50">Variable</span>
Expand All @@ -58,6 +75,7 @@
/>
</div>
</div>

<Transition>
<div v-if="showVariableChooseModal" class="flex flex-col justify-center w-full mx-1 my-3 align-center">
<input
Expand Down Expand Up @@ -86,6 +104,17 @@
<span class="w-full mb-1 text-sm text-slate-100/50">Multiplier</span>
<input v-model="miniWidget.options.variableMultiplier" class="w-full px-2 py-1 rounded-md bg-[#FFFFFF12]" />
</div>
<div class="flex flex-col items-center justify-between w-full mx-5">
<span class="w-full mb-1 text-sm text-slate-100/50">Decimal Places</span>
<input
v-model="miniWidget.options.decimalPlaces"
type="number"
min="0"
max="5"
placeholder="Auto-formatting"
class="w-full px-2 py-1 rounded-md bg-[#FFFFFF12]"
/>
</div>
</div>
<div class="flex flex-col items-center justify-between w-full mt-3">
<span class="w-full mb-1 text-sm text-slate-100/50">Icon</span>
Expand Down Expand Up @@ -184,14 +213,15 @@ const props = defineProps<{
const miniWidget = toRefs(props).miniWidget
onBeforeMount(() => {
// Set initial widget options if they don't exist
if (Object.keys(miniWidget.value.options).length === 0) {
Object.assign(miniWidget.value.options, {
displayName: '',
variableName: '',
iconName: 'mdi-help-box',
variableUnit: '%',
variableMultiplier: 1,
decimalPlaces: null,
widgetWidth: 136,
})
}
Expand All @@ -206,12 +236,18 @@ const widgetStore = useWidgetManagerStore()
const currentState = ref<unknown>(0)
const finalValue = computed(() => Number(miniWidget.value.options.variableMultiplier) * Number(currentState.value))
const parsedState = computed(() => {
if (currentState.value === undefined) {
return '--'
}
const value = finalValue.value
const decimalPlaces = miniWidget.value.options.decimalPlaces
if (decimalPlaces !== null && !isNaN(decimalPlaces)) {
return value.toFixed(decimalPlaces)
}
if (value < 0 && value > -10) return value.toFixed(1)
if (value <= -10 && value > -100) return value.toFixed(1)
if (value <= -100 && value > -1000) return value.toFixed(0)
Expand Down Expand Up @@ -280,6 +316,22 @@ const logCurrentState = (): void => {
}
}
watch(
() => miniWidget.value.options.decimalPlaces,
(newVal) => {
if (newVal === '' || newVal === null || newVal === undefined) {
miniWidget.value.options.decimalPlaces = null
} else {
const num = Number(newVal)
if (!isNaN(num) && num >= 0 && Number.isInteger(num)) {
miniWidget.value.options.decimalPlaces = num
} else {
miniWidget.value.options.decimalPlaces = null
}
}
}
)
watch(
finalValue,
() => {
Expand All @@ -291,6 +343,7 @@ watch(
)
watch(store.genericVariables, () => updateVariableState())
watch(
() => store.availableGenericVariables,
() => updateGenericVariablesNames(),
Expand Down

0 comments on commit aeb6be4

Please sign in to comment.