-
Notifications
You must be signed in to change notification settings - Fork 2.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add domain icon component and clean old files
- Loading branch information
Showing
23 changed files
with
379 additions
and
726 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
import { HassEntity } from "home-assistant-js-websocket"; | ||
import { computeStateDomain } from "./compute_state_domain"; | ||
import { updateIcon } from "./update_icon"; | ||
import { deviceTrackerIcon } from "./device_tracker_icon"; | ||
import { batteryIcon } from "./battery_icon"; | ||
|
||
export const stateIcon = ( | ||
stateObj: HassEntity, | ||
state?: string | ||
): string | undefined => { | ||
const domain = computeStateDomain(stateObj); | ||
const compareState = state ?? stateObj?.state; | ||
const dc = stateObj?.attributes.device_class; | ||
switch (domain) { | ||
case "update": | ||
return updateIcon(stateObj, compareState); | ||
|
||
case "sensor": | ||
if (dc === "battery") { | ||
return batteryIcon(stateObj, compareState); | ||
} | ||
break; | ||
|
||
case "device_tracker": | ||
return deviceTrackerIcon(stateObj, compareState); | ||
|
||
case "person": | ||
return compareState === "not_home" | ||
? "mdi:account-arrow-right" | ||
: "mdi:account"; | ||
|
||
case "sun": | ||
return compareState === "above_horizon" | ||
? "mdi:white-balance-sunny" | ||
: "mdi:weather-night"; | ||
|
||
case "input_boolean": | ||
return compareState === "on" | ||
? "mdi:check-circle-outline" | ||
: "mdi:close-circle-outline"; | ||
|
||
case "input_datetime": | ||
if (!stateObj?.attributes.has_date) { | ||
return "mdi:clock"; | ||
} | ||
if (!stateObj.attributes.has_time) { | ||
return "mdi:calendar"; | ||
} | ||
break; | ||
} | ||
return undefined; | ||
}; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,92 +1,59 @@ | ||
/** Return an icon representing a battery state. */ | ||
import { | ||
mdiBattery, | ||
mdiBattery10, | ||
mdiBattery20, | ||
mdiBattery30, | ||
mdiBattery40, | ||
mdiBattery50, | ||
mdiBattery60, | ||
mdiBattery70, | ||
mdiBattery80, | ||
mdiBattery90, | ||
mdiBatteryAlert, | ||
mdiBatteryAlertVariantOutline, | ||
mdiBatteryCharging, | ||
mdiBatteryCharging10, | ||
mdiBatteryCharging20, | ||
mdiBatteryCharging30, | ||
mdiBatteryCharging40, | ||
mdiBatteryCharging50, | ||
mdiBatteryCharging60, | ||
mdiBatteryCharging70, | ||
mdiBatteryCharging80, | ||
mdiBatteryCharging90, | ||
mdiBatteryChargingOutline, | ||
mdiBatteryUnknown, | ||
} from "@mdi/js"; | ||
import { HassEntity } from "home-assistant-js-websocket"; | ||
|
||
const BATTERY_ICONS = { | ||
10: mdiBattery10, | ||
20: mdiBattery20, | ||
30: mdiBattery30, | ||
40: mdiBattery40, | ||
50: mdiBattery50, | ||
60: mdiBattery60, | ||
70: mdiBattery70, | ||
80: mdiBattery80, | ||
90: mdiBattery90, | ||
100: mdiBattery, | ||
10: "mdi:battery-10", | ||
20: "mdi:battery-20", | ||
30: "mdi:battery-30", | ||
40: "mdi:battery-40", | ||
50: "mdi:battery-50", | ||
60: "mdi:battery-60", | ||
70: "mdi:battery-70", | ||
80: "mdi:battery-80", | ||
90: "mdi:battery-90", | ||
100: "mdi:battery", | ||
}; | ||
const BATTERY_CHARGING_ICONS = { | ||
10: mdiBatteryCharging10, | ||
20: mdiBatteryCharging20, | ||
30: mdiBatteryCharging30, | ||
40: mdiBatteryCharging40, | ||
50: mdiBatteryCharging50, | ||
60: mdiBatteryCharging60, | ||
70: mdiBatteryCharging70, | ||
80: mdiBatteryCharging80, | ||
90: mdiBatteryCharging90, | ||
100: mdiBatteryCharging, | ||
10: "mdi:battery-charging-10", | ||
20: "mdi:battery-charging-20", | ||
30: "mdi:battery-charging-30", | ||
40: "mdi:battery-charging-40", | ||
50: "mdi:battery-charging-50", | ||
60: "mdi:battery-charging-60", | ||
70: "mdi:battery-charging-70", | ||
80: "mdi:battery-charging-80", | ||
90: "mdi:battery-charging-90", | ||
100: "mdi:battery-charging", | ||
}; | ||
|
||
export const batteryStateIcon = ( | ||
batteryState: HassEntity, | ||
batteryChargingState?: HassEntity | ||
) => { | ||
const battery = batteryState.state; | ||
const batteryCharging = | ||
batteryChargingState && batteryChargingState.state === "on"; | ||
|
||
return batteryIcon(battery, batteryCharging); | ||
export const batteryIcon = (stateObj: HassEntity, state?: string) => { | ||
const level = state ?? stateObj.state; | ||
return batteryLevelIcon(level); | ||
}; | ||
|
||
export const batteryIcon = ( | ||
batteryState: number | string, | ||
batteryCharging?: boolean | ||
) => { | ||
const batteryValue = Number(batteryState); | ||
export const batteryLevelIcon = ( | ||
batteryLevel: number | string, | ||
isBatteryCharging?: boolean | ||
): string => { | ||
const batteryValue = Number(batteryLevel); | ||
if (isNaN(batteryValue)) { | ||
if (batteryState === "off") { | ||
return mdiBattery; | ||
if (batteryLevel === "off") { | ||
return "mdi:battery"; | ||
} | ||
if (batteryState === "on") { | ||
return mdiBatteryAlert; | ||
if (batteryLevel === "on") { | ||
return "mdi:battery-alert"; | ||
} | ||
return mdiBatteryUnknown; | ||
return "mdi:battery-unknown"; | ||
} | ||
|
||
const batteryRound = Math.round(batteryValue / 10) * 10; | ||
if (batteryCharging && batteryValue >= 10) { | ||
if (isBatteryCharging && batteryValue >= 10) { | ||
return BATTERY_CHARGING_ICONS[batteryRound]; | ||
} | ||
if (batteryCharging) { | ||
return mdiBatteryChargingOutline; | ||
if (isBatteryCharging) { | ||
return "mdi:battery-charging-outline"; | ||
} | ||
if (batteryValue <= 5) { | ||
return mdiBatteryAlertVariantOutline; | ||
return "mdi:battery-alert-variant-outline"; | ||
} | ||
return BATTERY_ICONS[batteryRound]; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
import { HassEntity } from "home-assistant-js-websocket"; | ||
|
||
export const deviceTrackerIcon = (stateObj: HassEntity, state?: string) => { | ||
const compareState = state ?? stateObj.state; | ||
if (stateObj?.attributes.source_type === "router") { | ||
return compareState === "home" ? "mdi:lan-connect" : "mdi:lan-disconnect"; | ||
} | ||
if ( | ||
["bluetooth", "bluetooth_le"].includes(stateObj?.attributes.source_type) | ||
) { | ||
return compareState === "home" ? "mdi:bluetooth-connect" : "mdi:bluetooth"; | ||
} | ||
return compareState === "not_home" | ||
? "mdi:account-arrow-right" | ||
: "mdi:account"; | ||
}; |
Oops, something went wrong.