Compare commits

..

5 Commits

8 changed files with 94 additions and 39 deletions
+10 -2
View File
@@ -3,13 +3,21 @@ const toggle = msg.payload
const ac = global.get('emmaBedroom.aircon.installed', "diskCon") const ac = global.get('emmaBedroom.aircon.installed', "diskCon")
const lastMode = flow.get("emmaBedroom.lastMode", "diskCon") const lastMode = flow.get("emmaBedroom.lastMode", "diskCon")
const bedTemp = states['input_number.emma_bedroom_bedtime_temp'].state const bedTemp = states['input_number.emma_bedroom_bedtime_temp'].state
const ecoHold = states['switch.emma_bedroom_aircon_eco_hold'].state
const fanMode = states['input_select.emma_bedroom_aircon_fan_mode'].state
const airconEntity = ["climate.emma_bedroom_aircon"] const airconEntity = ["climate.emma_bedroom_aircon"]
let setTemp = bedTemp let setTemp = bedTemp
let setEco = 'turn_off' let setEco = 'turn_on'
let setHvac = 'cool' let setHvac = 'cool'
let setAcFan = 'High' let setAcFan = fanMode
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off'
}
let sendHvac = { let sendHvac = {
"payload": { "payload": {
+1 -1
View File
@@ -11,7 +11,7 @@ let fanOnlyMsg = {
"topic": "Emma AC Mode: Fan Only" "topic": "Emma AC Mode: Fan Only"
} }
if (topic === 'emmabedroom-cooling') { if (topic === 'emmabedroom-climate') {
if (acMode === 'AC') { if (acMode === 'AC') {
node.status({fill:"green",shape:"dot",text:"AC Cooling"}) node.status({fill:"green",shape:"dot",text:"AC Cooling"})
return coolMsg return coolMsg
+14 -8
View File
@@ -18,6 +18,8 @@ const earlyNight = states["binary_sensor.early_night_mode"].state
const danger = states['binary_sensor.heat_warning'].attributes.danger const danger = states['binary_sensor.heat_warning'].attributes.danger
const meltdown = states['input_boolean.meltdown_protocol'].state const meltdown = states['input_boolean.meltdown_protocol'].state
const coolingActive = states['input_boolean.emma_bedroom_cooling_on'].state const coolingActive = states['input_boolean.emma_bedroom_cooling_on'].state
const ecoHold = states['input_boolean.emma_bedroom_aircon_eco_hold'].state
const fanModeAircon = states['input_select.emma_bedroom_aircon_fan_mode'].state
node.log("Emma Bedroom Climate: Constants Set") node.log("Emma Bedroom Climate: Constants Set")
// Define reusable constants // Define reusable constants
@@ -39,7 +41,7 @@ function convertToTitleCase(str) {
// init variables // init variables
let setTemp = dayTemp let setTemp = dayTemp
let setAcFan = 'auto' let setAcFan = fanModeAircon
let setEco = 'turn_on' let setEco = 'turn_on'
let setHvac = 'cool' let setHvac = 'cool'
let setCool = [] let setCool = []
@@ -97,7 +99,7 @@ if (time === 'day') {
} else if (earlyNight === 'on') { } else if (earlyNight === 'on') {
if (ac === 'on') { if (ac === 'on') {
if (danger === 'Extreme') { if (danger === 'Extreme') {
setTemp === bedTemp setTemp = bedTemp
} else { } else {
setTemp = nightTemp setTemp = nightTemp
} }
@@ -108,13 +110,9 @@ if (time === 'day') {
} else { } else {
setHvac = 'off' setHvac = 'off'
} }
if (hotDay === 'on') {
setEco = 'turn_off'
} else {
setEco = 'turn_on' setEco = 'turn_on'
} }
} }
}
// Night Time // Night Time
} else if (time === 'night') { } else if (time === 'night') {
// If this is being run at scheduled time, turn on input_boolean.emma_bedroom_cooling_on // If this is being run at scheduled time, turn on input_boolean.emma_bedroom_cooling_on
@@ -131,7 +129,11 @@ if (time === 'day') {
} }
// Decide eco mode // Decide eco mode
if (sleeping === 'on') { if (sleeping === 'on') {
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
} else { } else {
setEco = 'turn_on' setEco = 'turn_on'
} }
@@ -148,7 +150,11 @@ if (time === 'day') {
setPeople = 'turn_off' setPeople = 'turn_off'
if (ac === 'on') { if (ac === 'on') {
setTemp = bedTemp setTemp = bedTemp
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
if (schedMode === 'AC') { if (schedMode === 'AC') {
setHvac = 'cool' setHvac = 'cool'
setDisplay = 'turn_off' setDisplay = 'turn_off'
@@ -291,7 +297,7 @@ if (setDisplay.length > 0) {
flow.set('emmaBedroom.airconDisplay',setDisplay,'diskCon') flow.set('emmaBedroom.airconDisplay',setDisplay,'diskCon')
} }
flow.set('emmaBedroom.airconFanMode',setAcFan,'diskCon') flow.set('emmaBedroom.airconfanModeAircon',setAcFan,'diskCon')
// Log the parameters that were chosen, for debugging purposes // Log the parameters that were chosen, for debugging purposes
@@ -322,7 +328,7 @@ if (type === 'auto' && allowed === 'on' && meltdown === 'off' && vacation === 'o
node.status({ fill: "red", shape: "ring", text: "Blocked (sleep mode)" }) node.status({ fill: "red", shape: "ring", text: "Blocked (sleep mode)" })
node.log("Emma Bedroom Climate: Blocked (sleep mode)") node.log("Emma Bedroom Climate: Blocked (sleep mode)")
} else { } else {
if (topic === 'emmabedroom-cooling' && ac === 'on') { if (topic === 'emmabedroom-climate' && ac === 'on') {
node.status({ fill: "green", shape: "dot", text: "Cooling Schedule" }) node.status({ fill: "green", shape: "dot", text: "Cooling Schedule" })
node.send([[sendDisplay, sendHvac, sendTemp, sendAcFan, sendEco], null, null]) node.send([[sendDisplay, sendHvac, sendTemp, sendAcFan, sendEco], null, null])
node.log("Emma Bedroom Climate: Auto/Cooling") node.log("Emma Bedroom Climate: Auto/Cooling")
+19 -4
View File
@@ -1,15 +1,30 @@
const states = global.get('homeassistant.homeAssistant.states') const states = global.get('homeassistant.homeAssistant.states')
const sleeping = states['input_boolean.emma_sleeping'].state
if (sleeping !== 'on') { // Check if all settings support aircon usage
const ac = global.get('emmaBedroom.aircon.installed', "diskCon")
const allowed = states['input_boolean.emma_bedroom_climate_protocol'].state
const schedMode = states['input_select.scheduled_climate_mode_emma_bedroom'].state
const coolingActive = states["input_boolean.emma_bedroom_cooling_on"].state
const sleeping = states["input_boolean.emma_sleeping"].state
let proceed = false
if (ac === 'on' && allowed === 'on' && schedMode === 'AC' && coolingActive === 'on') {
proceed = true
}
if (sleeping != 'on') {
node.status({fill:'red',shape:'ring',text:'Emma not sleeping, watchdog disabled'}) node.status({fill:'red',shape:'ring',text:'Emma not sleeping, watchdog disabled'})
return null return null
} else if (proceed === false) {
node.status({fill:'red',shape:'ring',text:'Aircon not in use, watchdog disabled'})
return null
} }
const airconEntity = ['climate.emma_bedroom_aircon']
// Gather relevant attributes from the aircon entity // Gather relevant attributes from the aircon entity
const airconEntity = ['climate.emma_bedroom_aircon']
const airconState = msg.payload.state const airconState = msg.payload.state
const airconAttributes = msg.payload.attributes const airconAttributes = msg.payload.attributes
const airconEco = airconAttributes['eco_mode'] const airconEco = airconAttributes['eco_mode']
+10 -2
View File
@@ -3,16 +3,24 @@ const toggle = msg.payload
const ac = global.get('masterBedroom.aircon.installed', "diskCon") const ac = global.get('masterBedroom.aircon.installed', "diskCon")
const lastMode = flow.get("masterBedroom.lastMode", "diskCon") const lastMode = flow.get("masterBedroom.lastMode", "diskCon")
const bedTemp = states['input_number.master_bedroom_bedtime_temp'].state const bedTemp = states['input_number.master_bedroom_bedtime_temp'].state
const ecoHold = states['switch.master_bedroom_aircon_eco_hold'].state
const fanMode = states['input_select.master_bedroom_aircon_fan_mode'].state
const airconEntity = ["climate.master_bedroom_aircon"] const airconEntity = ["climate.master_bedroom_aircon"]
const fanEntity = ["fan.master_bedroom_fan"] const fanEntity = ["fan.master_bedroom_fan"]
let setTemp = bedTemp let setTemp = bedTemp
let setEco = 'turn_off' let setEco = 'turn_on'
let setHvac = 'cool' let setHvac = 'cool'
let setAcFan = 'High' let setAcFan = fanMode
let setFan = 'turn_off' let setFan = 'turn_off'
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off'
}
let sendFan = { let sendFan = {
"payload": { "payload": {
"action": `fan.${setFan}`, "action": `fan.${setFan}`,
+7 -5
View File
@@ -4,12 +4,14 @@ const states = global.get('homeassistant.homeAssistant.states')
const dayTemp = parseInt(states['input_number.master_bedroom_daytime_temp'].state) const dayTemp = parseInt(states['input_number.master_bedroom_daytime_temp'].state)
const nightTemp = parseInt(states['input_number.master_bedroom_night_temp'].state) const nightTemp = parseInt(states['input_number.master_bedroom_night_temp'].state)
const bedTemp = parseInt(states['input_number.master_bedroom_bedtime_temp'].state) const bedTemp = parseInt(states['input_number.master_bedroom_bedtime_temp'].state)
const ecoHold = states['switch.master_bedroom_aircon_eco_hold'].state
const fanModeAircon = states['input_select.master_bedroom_aircon_fan_mode'].state
let dayMode = { let dayMode = {
"power": "turn_on", "power": "turn_on",
"temp": dayTemp, "temp": dayTemp,
"hvac": "cool", "hvac": "cool",
"fan": "auto", "fan": fanModeAircon,
"eco": "turn_on" "eco": "turn_on"
} }
@@ -17,16 +19,16 @@ let nightMode = {
"power": "turn_on", "power": "turn_on",
"temp": nightTemp, "temp": nightTemp,
"hvac": "cool", "hvac": "cool",
"fan": "auto", "fan": fanModeAircon,
"eco": "turn_on" "eco": ecoHold === "on" ? "turn_on" : "turn_off"
} }
let bedMode = { let bedMode = {
"power": "turn_on", "power": "turn_on",
"temp": bedTemp, "temp": bedTemp,
"hvac": "cool", "hvac": "cool",
"fan": "auto", "fan": fanModeAircon,
"eco": "turn_off" "eco": ecoHold === "on" ? "turn_on" : "turn_off"
} }
let showerMode = { let showerMode = {
+13 -7
View File
@@ -23,6 +23,8 @@ const danger = states['binary_sensor.heat_warning'].attributes.danger
const meltdown = states['input_boolean.meltdown_protocol'].state const meltdown = states['input_boolean.meltdown_protocol'].state
const coolingActive = states['input_boolean.master_bedroom_cooling_on'].state const coolingActive = states['input_boolean.master_bedroom_cooling_on'].state
const echoDotDND = 'switch.basement_echo_dot_do_not_disturb_switch' const echoDotDND = 'switch.basement_echo_dot_do_not_disturb_switch'
const ecoHold = states['switch.master_bedroom_aircon_eco_hold'].state
const fanModeAircon = states['input_select.master_bedroom_aircon_fan_mode'].state
node.log("Master Bedroom Climate: Constants Set") node.log("Master Bedroom Climate: Constants Set")
// Define some entity IDs // Define some entity IDs
@@ -43,8 +45,8 @@ function convertToTitleCase(str) {
// init variables // init variables
let setTemp = dayTemp let setTemp = dayTemp
let setAcFan = 'auto' let setAcFan = fanModeAircon
let setEco = 'auto' let setEco = 'turn_on'
let setHvac = 'cool' let setHvac = 'cool'
let setFan = [] let setFan = []
let setCool = [] let setCool = []
@@ -116,7 +118,7 @@ if (time === 'day') {
} else if (earlyNight === 'on') { } else if (earlyNight === 'on') {
if (ac === 'on') { if (ac === 'on') {
if (danger === 'Extreme') { if (danger === 'Extreme') {
setTemp === bedTemp setTemp = bedTemp
} else { } else {
setTemp = nightTemp setTemp = nightTemp
} }
@@ -132,13 +134,9 @@ if (time === 'day') {
} else { } else {
setHvac = 'off' setHvac = 'off'
} }
if (hotDay === 'on') {
setEco = 'turn_off'
} else {
setEco = 'turn_on' setEco = 'turn_on'
} }
} }
}
// Night Time // Night Time
} else if (time === 'night') { } else if (time === 'night') {
// If this is being run at scheduled time, turn on input_boolean.master_bedroom_cooling_on // If this is being run at scheduled time, turn on input_boolean.master_bedroom_cooling_on
@@ -155,7 +153,11 @@ if (time === 'day') {
} }
// Decide eco mode // Decide eco mode
if (sleeping === 'on') { if (sleeping === 'on') {
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
} else { } else {
setEco = 'turn_on' setEco = 'turn_on'
} }
@@ -178,7 +180,11 @@ if (time === 'day') {
setPeople = 'turn_off' setPeople = 'turn_off'
if (ac === 'on') { if (ac === 'on') {
setTemp = bedTemp setTemp = bedTemp
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
if (acMode === 'AC') { if (acMode === 'AC') {
setHvac = 'cool' setHvac = 'cool'
setDisplay = 'turn_off' setDisplay = 'turn_off'
+12 -2
View File
@@ -9,12 +9,14 @@ const currentSetTemp = states['climate.master_bedroom_aircon'].attributes.temper
const coolingTime = states['input_boolean.master_bedroom_cooling_on'].state const coolingTime = states['input_boolean.master_bedroom_cooling_on'].state
const sleeping = states['input_boolean.master_bedroom_sleeping'].state const sleeping = states['input_boolean.master_bedroom_sleeping'].state
const hotDay = states['input_boolean.hot_day'].state const hotDay = states['input_boolean.hot_day'].state
const ecoHold = states['switch.master_bedroom_aircon_eco_hold'].state
const fanModeAircon = states['input_select.master_bedroom_aircon_fan_mode'].state
const topic = msg.topic const topic = msg.topic
const airconEntity = ["climate.master_bedroom_aircon"] const airconEntity = ["climate.master_bedroom_aircon"]
let setTemp = {} let setTemp = {}
let setEco = {} let setEco = 'turn_on'
let duration = {} let duration = {}
let end = {} let end = {}
let setHvac = {} let setHvac = {}
@@ -22,7 +24,11 @@ let setHvac = {}
if (topic === 'toggle') { if (topic === 'toggle') {
if (hotDay === 'on' || sleeping === 'on') { if (hotDay === 'on' || sleeping === 'on') {
setTemp = bedTemp setTemp = bedTemp
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
} else { } else {
setTemp = nightTemp setTemp = nightTemp
setEco = 'turn_on' setEco = 'turn_on'
@@ -31,7 +37,11 @@ if (topic === 'toggle') {
if (currentSetTemp == bedTemp) { if (currentSetTemp == bedTemp) {
setTemp = nightTemp setTemp = nightTemp
if (hotDay === 'on') { if (hotDay === 'on') {
if (ecoHold === 'on') {
setEco = 'turn_on'
} else {
setEco = 'turn_off' setEco = 'turn_off'
}
} else { } else {
setEco = 'turn_on' setEco = 'turn_on'
} }
@@ -109,7 +119,7 @@ let sendAcFan = {
"entity_id": airconEntity "entity_id": airconEntity
}, },
"data": { "data": {
"fan_mode": "auto" "fan_mode": fanModeAircon
} }
} }
} }