Merge pull request #4528 from blazoncek/ir-bugfix
Fix for "Send notifications on button press or IR" does not work when using "JSON remote" #4519
This commit is contained in:
		| @@ -611,9 +611,15 @@ static void decodeIRJson(uint32_t code) | ||||
|       handleSet(nullptr, cmdStr, false);                           // no stateUpdated() call here | ||||
|     } | ||||
|   } else { | ||||
|     // command is JSON object (TODO: currently will not handle irApplyToAllSelected correctly) | ||||
|     if (jsonCmdObj[F("psave")].isNull()) deserializeState(jsonCmdObj, CALL_MODE_BUTTON_PRESET); | ||||
|     else { | ||||
|     // command is JSON object | ||||
|     if (jsonCmdObj[F("psave")].isNull()) { | ||||
|       if (irApplyToAllSelected && jsonCmdObj["seg"].is<JsonArray>()) { | ||||
|         JsonObject seg = jsonCmdObj["seg"][0];                    // take 1st segment from array and use it to apply to all selected segments | ||||
|         seg.remove("id");                                         // remove segment ID if it exists | ||||
|         jsonCmdObj["seg"] = seg;                                  // replace array with object | ||||
|       } | ||||
|       deserializeState(jsonCmdObj, CALL_MODE_BUTTON_PRESET);      // **will call stateUpdated() with correct CALL_MODE** | ||||
|     } else { | ||||
|       uint8_t psave = jsonCmdObj[F("psave")].as<int>(); | ||||
|       char pname[33]; | ||||
|       sprintf_P(pname, PSTR("IR Preset %d"), psave); | ||||
| @@ -628,6 +634,7 @@ static void applyRepeatActions() | ||||
| { | ||||
|   if (irEnabled == 8) { | ||||
|     decodeIRJson(lastValidCode); | ||||
|     stateUpdated(CALL_MODE_BUTTON_PRESET); | ||||
|     return; | ||||
|   } else switch (lastRepeatableAction) { | ||||
|     case ACTION_BRIGHT_UP :      incBrightness();                            stateUpdated(CALL_MODE_BUTTON); return; | ||||
| @@ -664,7 +671,7 @@ static void decodeIR(uint32_t code) | ||||
|  | ||||
|   if (irEnabled == 8) { // any remote configurable with ir.json file | ||||
|     decodeIRJson(code); | ||||
|     stateUpdated(CALL_MODE_BUTTON); | ||||
|     stateUpdated(CALL_MODE_BUTTON_PRESET); | ||||
|     return; | ||||
|   } | ||||
|   if (code > 0xFFFFFF) return; //invalid code | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaž Kristan
					Blaž Kristan