From d1d736e487d9eb104dcae9def948066037afd2f0 Mon Sep 17 00:00:00 2001
From: Alejandro Acuña <alejandro.acuna@aluvisagrupo.com>
Date: Tue, 29 Apr 2025 14:47:02 +0000
Subject: [PATCH] jhfg

---
 libraries/server-git.rar                                                      |    0 
 svgDevicesTest/build/classes/Rtz/RtzMap.class                                 |    0 
 UI/Icons/24x24/alarm-configuration.png                                        |    0 
 svgDevicesTest/src/Rtz/mockers/RtzMockerMap.java                              |   43 +++++---
 svgDevicesTest/src/M_Controller/M_ControllerBig.java                          |    4 
 svgDevicesTest/build/classes/M_Controller/mockers/M_ControllerMockerMap.class |    0 
 svgDevicesTest/build/classes/AAAMain/SvgDeviceStatusTest.class                |    0 
 svgDevicesTest/build/classes/Rtz/mockers/RtzMockerMap.class                   |    0 
 svgDevicesTest/build/classes/M_Controller/M_ControllerMap.class               |    0 
 UI/SVG templates/alarm-configuration.svg                                      |   80 ++++++++++++++++
 svgDevicesTest/build/classes/M_Controller/M_ControllerBig.class               |    0 
 svgDevicesTest/src/Rtz/RtzMap.java                                            |    8 +
 svgDevicesTest/src/M_Controller/M_ControllerMap.java                          |   25 ++++
 svgDevicesTest/src/AAAMain/SvgDeviceStatusTest.java                           |    2 
 svgDevicesTest/src/Rtz/RtzMapComplex.java                                     |    2 
 Obras/Zaragoza/rtzserver/data/art.servers.rtzserver/symbols/9/Controller.svg  |  100 ++++++++++++++------
 svgDevicesTest/build/built-jar.properties                                     |    2 
 svgDevicesTest/src/M_Controller/mockers/M_ControllerMockerMap.java            |   22 ++--
 18 files changed, 223 insertions(+), 65 deletions(-)

diff --git a/Obras/Zaragoza/rtzserver/data/art.servers.rtzserver/symbols/9/Controller.svg b/Obras/Zaragoza/rtzserver/data/art.servers.rtzserver/symbols/9/Controller.svg
index d3f879b..cb69601 100644
--- a/Obras/Zaragoza/rtzserver/data/art.servers.rtzserver/symbols/9/Controller.svg
+++ b/Obras/Zaragoza/rtzserver/data/art.servers.rtzserver/symbols/9/Controller.svg
@@ -23,9 +23,9 @@
      borderopacity="1.0"
      inkscape:pageopacity="0.0"
      inkscape:pageshadow="2"
-     inkscape:zoom="15.839192"
-     inkscape:cx="-12.823288"
-     inkscape:cy="13.478538"
+     inkscape:zoom="5.6"
+     inkscape:cx="-39.351516"
+     inkscape:cy="45.026974"
      inkscape:document-units="mm"
      inkscape:current-layer="svg1894"
      showgrid="false"
@@ -40,10 +40,11 @@
      inkscape:window-maximized="1" />
   <metadata
      id="Metadata"
-     art.script="   private boolean flashOn = false;
+     art.script="  private boolean flashOn = false;
 
     public void timer()
     {
+        status();
     }
 
     public void status()
@@ -51,6 +52,7 @@
         flashOn = java.util.Calendar.getInstance().get(java.util.Calendar.SECOND) % 2 == 0;
       
         Device device = getDevice();
+        art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerInformation information = (art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerInformation) device.getDeviceInformation();
         art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerStatus status = (art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerStatus) device.getDeviceStatus();
         
         art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General statusGeneral = status.rtz32.general;
@@ -58,37 +60,76 @@
         SVGElement background = getElement(&quot;Background&quot;);
         SVGElement border = getElement(&quot;Border&quot;);
         
-        setAttribute(border, &quot;display&quot;, &quot;none&quot;,999);
-        setAttribute(background, &quot;display&quot;, &quot;none&quot;, 999);
+        setAttribute(border, &quot;display&quot;, &quot;inline&quot;,999);
+        setAttribute(background, &quot;display&quot;, &quot;inline&quot;, 999);
         
-        SVGElement controlMode = null;
-
-        if (status.status == art.library.model.devices.DeviceStatus.STATUS_UNKNOWN ||  status.status == art.library.model.devices.DeviceStatus.STATUS_OFFLINE)
+        if (information.mode == art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerInformation.MODE_NON_CENTRALIZED)
         {
-            setAttribute(background, &quot;fill&quot;, &quot;#00FF00&quot;, 999);
-            setAttribute(background, &quot;display&quot;, flashOn || status.status == art.library.model.devices.DeviceStatus.STATUS_OFFLINE ? &quot;inline&quot; : &quot;none&quot;, 999);
-        } 
-        else if (statusGeneral.state == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.STATE_FLASHING)
-        {
-            setAttribute(background, &quot;fill&quot;, &quot;#FFFFFF&quot;, 999);
-            setAttribute(background, &quot;display&quot;, flashOn ? &quot;inline&quot; : &quot;none&quot;, 999);
+            setAttribute(border, &quot;fill&quot;, &quot;#FFFFFF&quot;,999);
+            setAttribute(background, &quot;fill&quot;, &quot;#FFFFFF&quot;,999);
         }
         else
         {
-            controlMode = statusGeneral.semiactuated  ? border : background;
-        }
+            if (status.rtz32.centralized.centralized == false)
+            {
+                setAttribute(border, &quot;fill&quot;, &quot;#808080&quot;, 999);
+                setAttribute(background, &quot;fill&quot;, &quot;#808080&quot;, 999);
+            } 
+            else
+            {
+                boolean semiactuated = status.rtz32.general.semiactuated ;
+                boolean offline = false;
+                
+                if (device.getAlarm(&quot;alarm_controller_offline&quot;) &gt; 0 || device.getAlarm(&quot;alarm_offline&quot;) &gt; 0)
+                {
+                    offline = true;
+                    setAttribute(border, &quot;display&quot;, flashOn ? &quot;inline&quot; : &quot;none&quot;, 999);
+                    setAttribute(background, &quot;display&quot;, flashOn ? &quot;inline&quot; : &quot;none&quot;, 999);
+                }
+                
+                if (status.rtz32.general.control == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.CONTROL_COMPUTER)
+                {
+                    setAttribute(border, &quot;fill&quot;, &quot;#00FF00&quot;, 999);
+                    setAttribute(background, &quot;fill&quot;, &quot;#00FF00&quot;, 999);
+                    
+                    if(offline == true)
+                    {
+                        setAttribute(background, &quot;display&quot;, flashOn || semiactuated ? &quot;none&quot; : &quot;inline&quot;, 999);
+                        setAttribute(border, &quot;display&quot;, flashOn ? &quot;none&quot; : &quot;inline&quot;, 999);
+                    }
+                    
+                    if(semiactuated)
+                        setAttribute(background, &quot;display&quot;, flashOn || semiactuated ? &quot;none&quot; : &quot;inline&quot;, 999);
+                }
+                else if (status.rtz32.general.control == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.CONTROL_LOCAL)
+                {
+                    setAttribute(border, &quot;fill&quot;, &quot;#FF0000&quot;, 999);
+                    setAttribute(background, &quot;fill&quot;, &quot;#FF0000&quot;, 999);
+                   
+                    if (offline == true)
+                    {
+                        setAttribute(background, &quot;display&quot;, flashOn || semiactuated ? &quot;none&quot; : &quot;inline&quot;, 999);
+                        setAttribute(border, &quot;display&quot;, flashOn ? &quot;none&quot; : &quot;inline&quot;, 999);
+                    }
+                    
+                     if(semiactuated)
+                        setAttribute(background, &quot;display&quot;, flashOn || semiactuated ? &quot;none&quot; : &quot;inline&quot;, 999);
+                }
 
-        if (controlMode != null)
-        {
-            if (statusGeneral.control == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.CONTROL_LOCAL)
-            {
-                setAttribute(controlMode, &quot;fill&quot;, &quot;#FF0000&quot;, 999);
+                if (device.getAlarm(&quot;alarm_controller_offline&quot;) &lt;= 0 &amp;&amp; device.getAlarm(&quot;alarm_offline&quot;) &lt;= 0)
+                {
+                    if (art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller.class.cast(device).getDeviceAlarms().rtz32.flashing.getServerityAlarm() &gt; 0)
+                    {
+                        setAttribute(border, &quot;fill&quot;, &quot;#FFFF00&quot;, 999);
+                        setAttribute(background, &quot;fill&quot;, &quot;#FFFF00&quot;, 999);
+                        setAttribute(border, &quot;display&quot;, flashOn ? &quot;inline&quot; : &quot;none&quot;, 999);
+                        setAttribute(background, &quot;display&quot;, flashOn ? &quot;inline&quot; : &quot;none&quot;, 999);
+                        
+                        if(semiactuated)
+                            setAttribute(background, &quot;display&quot;,&quot;none&quot;, 999);
+                    }
+                }
             }
-            else if (statusGeneral.control == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.CONTROL_COMPUTER)
-            {
-                setAttribute(controlMode, &quot;fill&quot;, &quot;#00FF00&quot;, 999);
-            }
-            setAttribute(controlMode, &quot;display&quot;, &quot;inline&quot;, 999);
         }
     }
 
@@ -110,8 +151,7 @@
             }
         } 
         catch (Exception ex){}
-    }
-">
+    }">
     <rdf:RDF>
       <cc:Work
          rdf:about="">
diff --git a/UI/Icons/24x24/alarm-configuration.png b/UI/Icons/24x24/alarm-configuration.png
new file mode 100644
index 0000000..d521b7e
--- /dev/null
+++ b/UI/Icons/24x24/alarm-configuration.png
Binary files differ
diff --git a/UI/SVG templates/alarm-configuration.svg b/UI/SVG templates/alarm-configuration.svg
new file mode 100644
index 0000000..30d666c
--- /dev/null
+++ b/UI/SVG templates/alarm-configuration.svg
@@ -0,0 +1,80 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   width="24"
+   height="24"
+   viewBox="0 0 6.3499999 6.3500002"
+   version="1.1"
+   id="svg8"
+   inkscape:export-filename="C:\Users\Konstantin\Documents\LocalBackup\UI\Icons\24x24\send-working.png"
+   inkscape:export-xdpi="95.380096"
+   inkscape:export-ydpi="95.380096"
+   inkscape:version="0.92.5 (2060ec1f9f, 2020-04-08)"
+   sodipodi:docname="alarm-configuration.svg">
+  <defs
+     id="defs2" />
+  <sodipodi:namedview
+     id="base"
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1.0"
+     inkscape:pageopacity="0.0"
+     inkscape:pageshadow="2"
+     inkscape:zoom="15.839192"
+     inkscape:cx="7.0600233"
+     inkscape:cy="8.6561954"
+     inkscape:document-units="mm"
+     inkscape:current-layer="layer1"
+     showgrid="false"
+     units="px"
+     inkscape:window-width="1920"
+     inkscape:window-height="1027"
+     inkscape:window-x="-8"
+     inkscape:window-y="-8"
+     inkscape:window-maximized="1" />
+  <metadata
+     id="metadata5">
+    <rdf:RDF>
+      <cc:Work
+         rdf:about="">
+        <dc:format>image/svg+xml</dc:format>
+        <dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+        <dc:title></dc:title>
+      </cc:Work>
+    </rdf:RDF>
+  </metadata>
+  <g
+     inkscape:label="Capa 1"
+     inkscape:groupmode="layer"
+     id="layer1"
+     transform="translate(0,-290.64998)">
+    <g
+       transform="matrix(0.00567882,0,0,0.00567882,3.4176231,294.07248)"
+       id="g2186"
+       style="stroke-width:1.13664603">
+      <g
+         id="g2184"
+         style="stroke-width:1.13664603">
+        <path
+           inkscape:connector-curvature="0"
+           d="m 501.818,90.998 c -1.876,-4.733 -6.008,-8.203 -10.993,-9.234 -4.991,-1.033 -10.156,0.516 -13.756,4.116 l -77.994,77.994 -41.932,-9.016 -9.015,-41.932 77.994,-77.995 c 3.6,-3.6 5.146,-8.77 4.116,-13.755 -1.031,-4.986 -4.502,-9.117 -9.234,-10.995 -53.547,-21.234 -114.462,-8.643 -155.186,32.079 -19.604,19.604 -33.066,44.227 -38.93,71.206 -5.017,23.082 -4.312,46.931 1.991,69.544 L 20.735,391.154 C 7.363,404.524 0,422.301 0,441.21 0,460.119 7.363,477.896 20.734,491.266 34.105,504.637 51.881,512 70.79,512 c 18.908,0 36.686,-7.363 50.056,-20.734 L 328.99,283.122 c 22.614,6.302 46.462,7.006 69.543,1.99 26.98,-5.864 51.603,-19.326 71.207,-38.93 40.723,-40.722 53.313,-101.637 32.078,-155.184 z"
+           id="path2182"
+           style="stroke-width:1.13664603" />
+      </g>
+    </g>
+    <path
+       style="opacity:1;fill:#000000;fill-opacity:1;stroke:none;stroke-width:6.50078773;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:0.64313725"
+       d="M 9.3007812 0.02734375 A 9.2999367 9.5535711 0 0 0 0 9.5800781 A 9.2999367 9.5535711 0 0 0 9.3007812 19.134766 A 9.2999367 9.5535711 0 0 0 18.599609 9.5800781 A 9.2999367 9.5535711 0 0 0 9.3007812 0.02734375 z M 9.3261719 2.0039062 A 0.6883818 0.6883818 0 0 1 10.033203 2.6914062 L 10.033203 3.4433594 A 4.1302896 4.1302896 0 0 1 13.476562 7.5117188 L 13.476562 11.640625 L 14.853516 13.017578 L 3.8378906 13.017578 L 5.2148438 11.640625 L 5.2148438 7.5117188 A 4.1302896 4.1302896 0 0 1 8.6582031 3.4433594 L 8.6582031 2.6914062 A 0.6883818 0.6883818 0 0 1 9.3261719 2.0039062 z M 7.96875 14.394531 L 10.722656 14.394531 A 1.3767633 1.3767633 0 0 1 7.96875 14.394531 z "
+       transform="matrix(0.26458333,0,0,0.26458333,0,290.64998)"
+       id="path827" />
+  </g>
+</svg>
diff --git a/libraries/server-git.rar b/libraries/server-git.rar
index f3193f3..16778be 100644
--- a/libraries/server-git.rar
+++ b/libraries/server-git.rar
Binary files differ
diff --git a/svgDevicesTest/build/built-jar.properties b/svgDevicesTest/build/built-jar.properties
index 2848ab2..3b85525 100644
--- a/svgDevicesTest/build/built-jar.properties
+++ b/svgDevicesTest/build/built-jar.properties
@@ -1,4 +1,4 @@
-#Wed, 26 Feb 2025 13:30:34 +0100
+#Wed, 16 Apr 2025 12:23:14 +0200
 
 
 D\:\\LocalBackup\\svgDevicesTest=
diff --git a/svgDevicesTest/build/classes/AAAMain/SvgDeviceStatusTest.class b/svgDevicesTest/build/classes/AAAMain/SvgDeviceStatusTest.class
index ed781a8..d8242b5 100644
--- a/svgDevicesTest/build/classes/AAAMain/SvgDeviceStatusTest.class
+++ b/svgDevicesTest/build/classes/AAAMain/SvgDeviceStatusTest.class
Binary files differ
diff --git a/svgDevicesTest/build/classes/M_Controller/M_ControllerBig.class b/svgDevicesTest/build/classes/M_Controller/M_ControllerBig.class
index a1e3958..b8eca75 100644
--- a/svgDevicesTest/build/classes/M_Controller/M_ControllerBig.class
+++ b/svgDevicesTest/build/classes/M_Controller/M_ControllerBig.class
Binary files differ
diff --git a/svgDevicesTest/build/classes/M_Controller/M_ControllerMap.class b/svgDevicesTest/build/classes/M_Controller/M_ControllerMap.class
index 5c4ed3d..e9d5f51 100644
--- a/svgDevicesTest/build/classes/M_Controller/M_ControllerMap.class
+++ b/svgDevicesTest/build/classes/M_Controller/M_ControllerMap.class
Binary files differ
diff --git a/svgDevicesTest/build/classes/M_Controller/mockers/M_ControllerMockerMap.class b/svgDevicesTest/build/classes/M_Controller/mockers/M_ControllerMockerMap.class
index c4c739c..fd7644a 100644
--- a/svgDevicesTest/build/classes/M_Controller/mockers/M_ControllerMockerMap.class
+++ b/svgDevicesTest/build/classes/M_Controller/mockers/M_ControllerMockerMap.class
Binary files differ
diff --git a/svgDevicesTest/build/classes/Rtz/RtzMap.class b/svgDevicesTest/build/classes/Rtz/RtzMap.class
index 28aa133..f9f4a24 100644
--- a/svgDevicesTest/build/classes/Rtz/RtzMap.class
+++ b/svgDevicesTest/build/classes/Rtz/RtzMap.class
Binary files differ
diff --git a/svgDevicesTest/build/classes/Rtz/mockers/RtzMockerMap.class b/svgDevicesTest/build/classes/Rtz/mockers/RtzMockerMap.class
index 2a7737c..657592b 100644
--- a/svgDevicesTest/build/classes/Rtz/mockers/RtzMockerMap.class
+++ b/svgDevicesTest/build/classes/Rtz/mockers/RtzMockerMap.class
Binary files differ
diff --git a/svgDevicesTest/src/AAAMain/SvgDeviceStatusTest.java b/svgDevicesTest/src/AAAMain/SvgDeviceStatusTest.java
index 01903c4..0b77b6d 100644
--- a/svgDevicesTest/src/AAAMain/SvgDeviceStatusTest.java
+++ b/svgDevicesTest/src/AAAMain/SvgDeviceStatusTest.java
@@ -56,7 +56,7 @@
 public class SvgDeviceStatusTest
 {
     
-    private static final SvgMocker SELECTED_MOCKER = SvgMocker.M_Controller;
+    private static final SvgMocker SELECTED_MOCKER = SvgMocker.RTZMap;
     
     public static String mapPath;
     
diff --git a/svgDevicesTest/src/M_Controller/M_ControllerBig.java b/svgDevicesTest/src/M_Controller/M_ControllerBig.java
index 9c17681..21c6932 100644
--- a/svgDevicesTest/src/M_Controller/M_ControllerBig.java
+++ b/svgDevicesTest/src/M_Controller/M_ControllerBig.java
@@ -502,6 +502,10 @@
                     setAttribute(thunderbolt, "display", "inline");
                     setAttribute(thunderbolt, "fill-opacity", "1.0", 999);
                     setAttribute(thunderbolt, "fill", color, 999);
+                    
+                    setAttribute(border, "stroke", "#0000FF");
+                    setAttribute(border, "stroke-width", 10.5);
+
                 } else if (commands.userControlPlan == art.library.model.devices.colors.controller.M.M_ControllerCommands.CONDITION_NO)
                 {
                     setAttribute(ribbon, "display", "inline");
diff --git a/svgDevicesTest/src/M_Controller/M_ControllerMap.java b/svgDevicesTest/src/M_Controller/M_ControllerMap.java
index f17b24c..aa2e4f5 100644
--- a/svgDevicesTest/src/M_Controller/M_ControllerMap.java
+++ b/svgDevicesTest/src/M_Controller/M_ControllerMap.java
@@ -44,7 +44,8 @@
             {
                 statusSubcontroller(controllerStatus.lsubcontroller.get(i).number);
             }
-        } catch (Exception e)
+        } 
+        catch (Exception e)
         {
             e.printStackTrace();
         }
@@ -174,8 +175,16 @@
             setAttribute(alarm, "display", "none");
             setAttribute(icon, "fill", "#800080", 999);
             setText("Text number", String.format("%05d", controllerInformation.number));
-            DeviceCommands deviceCommands = getDeviceCommands();
-            if (!deviceCommands.isEmpty())
+            
+            commands = new art.library.model.devices.colors.controller.M.M_ControllerCommands();
+            {
+                art.library.model.devices.colors.controller.M.M_ControllerCommands controllerCommands = (art.library.model.devices.colors.controller.M.M_ControllerCommands)commands;
+                {
+                    controllerCommands.userControlPlan = 1;
+                }
+            }
+
+            if (!commands.isEmpty())
             {
                 switch (commands.colorsMode)
                 {
@@ -193,6 +202,8 @@
                         setAttribute(background, "fill", "#00FF00");
                         setAttribute(icon, "fill", "#008000");
                         setAttribute(border, "stroke", "#008000");
+                        
+                     
                         break;
                     default:
                         setAttribute(background, "fill", "#00FF00");
@@ -200,7 +211,13 @@
                         setAttribute(border, "stroke", "#008000");
                         break;
                 }
-            } else
+            
+                   if (art.library.model.devices.colors.controller.M.M_ControllerCommands.class.cast(commands).userControlPlan == DeviceCommands.CONDITION_YES)
+                        {
+                            setAttribute(border, "stroke", "#0000FF");
+                        }
+            } 
+            else
             {
                 setAttribute(background, "fill", "#0000FF");
                 setAttribute(icon, "fill", "#000080");
diff --git a/svgDevicesTest/src/M_Controller/mockers/M_ControllerMockerMap.java b/svgDevicesTest/src/M_Controller/mockers/M_ControllerMockerMap.java
index 9a89ec2..ceb0840 100644
--- a/svgDevicesTest/src/M_Controller/mockers/M_ControllerMockerMap.java
+++ b/svgDevicesTest/src/M_Controller/mockers/M_ControllerMockerMap.java
@@ -28,17 +28,17 @@
         
        try
        {
-           M_Controller mock = (M_Controller)Serialization.deserialize(M_Controller.class, new File("C:\\Users\\Konstantin\\Desktop\\junction.txt"));
-           int i = 0;
-           
-           controller.status = mock.status;
-           controller.information = mock.information;
-           controller.alarms = mock.alarms;
-           controller.realtime = mock.realtime;
-           controller.graphics = mock.graphics;
-           controller.configuration = mock.configuration;
-           
-           controller.getDeviceStatus().getStatusSubcontroller().userControlPlan = 1;
+           M_Controller mock = (M_Controller)Serialization.deserialize(M_Controller.class, new File("C:\\Users\\Konstantin\\Desktop\\controller.txt"));
+//           int i = 0;
+//           
+//           controller.status = mock.status;
+//           controller.information = mock.information;
+//           controller.alarms = mock.alarms;
+//           controller.realtime = mock.realtime;
+//           controller.graphics = mock.graphics;
+//           controller.configuration = mock.configuration;
+//           
+//           controller.getDeviceStatus().getStatusSubcontroller().userControlPlan = 1;
        
        } 
        catch (SerializationException ex)
diff --git a/svgDevicesTest/src/Rtz/RtzMap.java b/svgDevicesTest/src/Rtz/RtzMap.java
index cf2f2c9..7ed8ebd 100644
--- a/svgDevicesTest/src/Rtz/RtzMap.java
+++ b/svgDevicesTest/src/Rtz/RtzMap.java
@@ -76,6 +76,9 @@
                         setAttribute(background, "display", flashOn || semiactuated ? "none" : "inline", 999);
                         setAttribute(border, "display", flashOn ? "none" : "inline", 999);
                     }
+                    
+                    if(semiactuated)
+                        setAttribute(background, "display", flashOn || semiactuated ? "none" : "inline", 999);
                 }
                 else if (status.rtz32.general.control == art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General.CONTROL_LOCAL)
                 {
@@ -87,11 +90,14 @@
                         setAttribute(background, "display", flashOn || semiactuated ? "none" : "inline", 999);
                         setAttribute(border, "display", flashOn ? "none" : "inline", 999);
                     }
+                    
+                     if(semiactuated)
+                        setAttribute(background, "display", flashOn || semiactuated ? "none" : "inline", 999);
                 }
 
                 if (device.getAlarm("alarm_controller_offline") <= 0 && device.getAlarm("alarm_offline") <= 0)
                 {
-                    if (art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller.class.cast(device).getDeviceAlarms().rtz32.flashing.getServerityAlarm() > 0)
+                    if (art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller.class.cast(device).getDeviceStatus().rtz32.general.state == status.rtz32.general.STATE_FLASHING)
                     {
                         setAttribute(border, "fill", "#FFFF00", 999);
                         setAttribute(background, "fill", "#FFFF00", 999);
diff --git a/svgDevicesTest/src/Rtz/RtzMapComplex.java b/svgDevicesTest/src/Rtz/RtzMapComplex.java
index bf5c063..f76b8b4 100644
--- a/svgDevicesTest/src/Rtz/RtzMapComplex.java
+++ b/svgDevicesTest/src/Rtz/RtzMapComplex.java
@@ -132,7 +132,7 @@
                 }
                 if (device.getAlarm("alarm_controller_offline") <= 0 && device.getAlarm("alarm_offline") <= 0)
                 {
-                    if (art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller.class.cast(device).getDeviceAlarms().rtz32.flashing.getServerityAlarm() > 0)
+                    if (art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller.class.cast(device).getDeviceStatus().rtz32.general.state == controllerStatus.rtz32.general.STATE_FLASHING)
                     {
                         setAttribute(background, "fill", "#FFFF00", 999);
                         setAttribute(ribbon, "stroke", "#FFFF00", 999);
diff --git a/svgDevicesTest/src/Rtz/mockers/RtzMockerMap.java b/svgDevicesTest/src/Rtz/mockers/RtzMockerMap.java
index 67891ea..97fa75e 100644
--- a/svgDevicesTest/src/Rtz/mockers/RtzMockerMap.java
+++ b/svgDevicesTest/src/Rtz/mockers/RtzMockerMap.java
@@ -2,12 +2,13 @@
 
 import Mocker.IDeviceMocker;
 import Rtz.RtzMap;
+import art.library.interop.serialization.Serialization;
 import art.library.model.devices.colors.controller.RTZ32.RTZ32_Controller;
-import art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerInformation;
-import art.library.model.devices.colors.controller.RTZ32.RTZ32_ControllerStatus;
-import art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_Centralized;
-import art.library.model.devices.colors.controller.RTZ32.status.RTZ32_Status_General;
 import devices.mockers.LocalFileDeviceMocker;
+import java.nio.file.Files;
+import java.nio.file.Paths;
+import java.util.logging.Level;
+import java.util.logging.Logger;
 import svgdevicestest.mock.*;
 
 public class RtzMockerMap extends DeviceMocker implements IDeviceMocker
@@ -26,24 +27,34 @@
     @Override
     public void updateDevice(boolean active) 
     {
-//      RTZ32_Controller.class.cast(device).getDeviceInformation().mode  = RTZ32_ControllerInformation.MODE_NON_CENTRALIZED;
-        RTZ32_Controller.class.cast(device).getDeviceInformation().mode  = RTZ32_ControllerInformation.MODE_NON_CENTRALIZED;
-        
-        RTZ32_ControllerStatus status = (RTZ32_ControllerStatus)device.getDeviceStatus();
-        status.rtz32.general.control = RTZ32_Status_General.CONTROL_LOCAL;
-        status.rtz32.general.semiactuated = false;
-        status.rtz32.centralized = new RTZ32_Status_Centralized();
-        status.rtz32.centralized.centralized = true;
-        
-        device.setAlarm("alarm_offline", true);
-        device.setAlarm("alarm_flashing_inputs_key", false);
+       try
+       {
+         
+           String dv =   new String(Files.readAllBytes(Paths.get("C:\\Users\\Konstantin\\Desktop\\rtz32_controller.txt")));
+           
+           RTZ32_Controller controller = Serialization.deserialize(RTZ32_Controller.class, dv);
+           
+           int i = 0;
+           
+//           Device controller = Serialization.deserialize(Device.class, "C:\\Users\\Konstantin\\Desktop\\rtz32_controller.txt");
+           
+           device.status = controller.status;
+           device.alarms = controller.alarms;
+           device.information = controller.information;
+           device.configuration = controller.configuration;
+           
+       } 
+       catch (Exception ex)
+       {
+           Logger.getLogger(RtzMockerMap.class.getName()).log(Level.SEVERE, null, ex);
+       }
         
     }
 
     @Override
     public String getFilePath() 
     {
-        return "C:\\Users\\Konstantin\\Documents\\LocalBackup\\Obras\\Zaragoza\\rtzserver\\data\\art.servers.rtzserver\\symbols\\9\\Controller.svg";
+        return "D:\\LocalBackup\\Obras\\Zaragoza\\rtzserver\\data\\art.servers.rtzserver\\symbols\\9\\Controller.svg";
     }
 
     @Override

--
Gitblit v1.10.0