diff --git a/src/PepperDash.Essentials.Core/Lighting/Lighting Interfaces.cs b/src/PepperDash.Essentials.Core/Lighting/Lighting Interfaces.cs
index 6c0eaad3..1ff0508f 100644
--- a/src/PepperDash.Essentials.Core/Lighting/Lighting Interfaces.cs
+++ b/src/PepperDash.Essentials.Core/Lighting/Lighting Interfaces.cs
@@ -1,10 +1,5 @@
using System;
using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using Crestron.SimplSharp;
-
-using PepperDash.Core;
namespace PepperDash.Essentials.Core.Lighting
{
@@ -23,6 +18,11 @@ namespace PepperDash.Essentials.Core.Lighting
}
+ public interface ILightingScenesDynamic
+ {
+ event EventHandler LightingScenesUpdated;
+ }
+
///
/// Requirements for a device that implements master raise/lower
///
diff --git a/src/PepperDash.Essentials.Core/Lighting/LightingScene.cs b/src/PepperDash.Essentials.Core/Lighting/LightingScene.cs
index 772a58b7..b0e0ddbe 100644
--- a/src/PepperDash.Essentials.Core/Lighting/LightingScene.cs
+++ b/src/PepperDash.Essentials.Core/Lighting/LightingScene.cs
@@ -26,6 +26,9 @@ namespace PepperDash.Essentials.Core.Lighting
}
}
+ [JsonProperty("sortOrder", NullValueHandling = NullValueHandling.Ignore)]
+ public int SortOrder { get; set; }
+
[JsonIgnore]
public BoolFeedback IsActiveFeedback { get; set; }
diff --git a/src/PepperDash.Essentials.MobileControl.Messengers/Messengers/LightingBaseMessenger.cs b/src/PepperDash.Essentials.MobileControl.Messengers/Messengers/LightingBaseMessenger.cs
index c8973aae..8ae91d36 100644
--- a/src/PepperDash.Essentials.MobileControl.Messengers/Messengers/LightingBaseMessenger.cs
+++ b/src/PepperDash.Essentials.MobileControl.Messengers/Messengers/LightingBaseMessenger.cs
@@ -8,15 +8,14 @@ namespace PepperDash.Essentials.AppServer.Messengers
{
public class ILightingScenesMessenger : MessengerBase
{
- protected ILightingScenes Device { get; private set; }
+ private ILightingScenes lightingScenesDevice;
public ILightingScenesMessenger(string key, ILightingScenes device, string messagePath)
: base(key, messagePath, device as IKeyName)
{
- Device = device ?? throw new ArgumentNullException("device");
- Device.LightingSceneChange += new EventHandler(LightingDevice_LightingSceneChange);
-
+ lightingScenesDevice = device ?? throw new ArgumentNullException("device");
+ lightingScenesDevice.LightingSceneChange += new EventHandler(LightingDevice_LightingSceneChange);
}
private void LightingDevice_LightingSceneChange(object sender, LightingSceneChangeEventArgs e)
@@ -38,8 +37,13 @@ namespace PepperDash.Essentials.AppServer.Messengers
AddAction("/selectScene", (id, content) =>
{
var s = content.ToObject();
- Device.SelectScene(s);
+ lightingScenesDevice.SelectScene(s);
});
+
+ if(!(lightingScenesDevice is ILightingScenesDynamic lightingScenesDynamic))
+ return;
+
+ lightingScenesDynamic.LightingScenesUpdated += (s, e) => SendFullStatus();
}
@@ -47,8 +51,8 @@ namespace PepperDash.Essentials.AppServer.Messengers
{
var state = new LightingBaseStateMessage
{
- Scenes = Device.LightingScenes,
- CurrentLightingScene = Device.CurrentLightingScene
+ Scenes = lightingScenesDevice.LightingScenes,
+ CurrentLightingScene = lightingScenesDevice.CurrentLightingScene
};
PostStatusMessage(state);