Skip to content

Commit

Permalink
Merge pull request sebirdman#53 from noelbundick/master
Browse files Browse the repository at this point in the history
support more accessories
  • Loading branch information
njobrien1006 authored Jun 12, 2023
2 parents 49bc7cc + 54cce26 commit c4f32c0
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 6 deletions.
6 changes: 4 additions & 2 deletions custom_components/traeger/climate.py
Original file line number Diff line number Diff line change
Expand Up @@ -243,14 +243,16 @@ def current_temperature(self):
"""Return the current temperature."""
if self.grill_accessory is None:
return 0
return self.grill_accessory["probe"]["get_temp"]
acc_type = self.grill_accessory["type"]
return self.grill_accessory[acc_type]["get_temp"]

@property
def target_temperature(self):
"""Return the temperature we try to reach."""
if self.grill_accessory is None:
return 0
return self.grill_accessory["probe"]["set_temp"]
acc_type = self.grill_accessory["type"]
return self.grill_accessory[acc_type]["set_temp"]

@property
def max_temp(self):
Expand Down
2 changes: 1 addition & 1 deletion custom_components/traeger/entity.py
Original file line number Diff line number Diff line change
Expand Up @@ -103,7 +103,7 @@ def grill_add_accessories(self):
if self.device_state is None:
return
for accessory in self.device_state["acc"]:
if accessory["type"] == "probe":
if accessory["type"] in ["probe", "btprobe", "hob"]:
if accessory["uuid"] not in self.accessory_status:
if self.probe_entity:
self.async_add_devices([
Expand Down
9 changes: 6 additions & 3 deletions custom_components/traeger/sensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -323,14 +323,17 @@ def state(self):
if self.grill_accessory is None:
return "idle"

target_temp = self.grill_accessory["probe"]["set_temp"]
probe_temp = self.grill_accessory["probe"]["get_temp"]
acc_type = self.grill_accessory["type"]
target_temp = self.grill_accessory[acc_type]["set_temp"]
probe_temp = self.grill_accessory[acc_type]["get_temp"]
target_changed = target_temp != self.previous_target_temp
grill_mode = self.grill_state["system_status"]
fell_out_temp = 102 if self.grill_units == TEMP_CELSIUS else 215

# Latch probe alarm, reset if target changed or grill leaves active modes
if self.grill_accessory["probe"]["alarm_fired"]:
if "alarm_fired" not in self.grill_accessory[acc_type]:
self.probe_alarm = False
elif self.grill_accessory[acc_type]["alarm_fired"]:
self.probe_alarm = True
elif ((target_changed and target_temp != 0) or
(grill_mode not in self.active_modes)):
Expand Down

0 comments on commit c4f32c0

Please sign in to comment.