From 43b0d5870d528f23ecd6aeceb6cfd4325188b46f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 01 七月 2021 15:50:43 +0800
Subject: [PATCH] Revert "1"

---
 HDL_ON/Entity/Room.cs |  548 ++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 405 insertions(+), 143 deletions(-)

diff --git a/HDL_ON/Entity/Room.cs b/HDL_ON/Entity/Room.cs
index 5c0cdcb..609e788 100644
--- a/HDL_ON/Entity/Room.cs
+++ b/HDL_ON/Entity/Room.cs
@@ -1,12 +1,14 @@
 锘縰sing System;
 using System.Collections.Generic;
+using HDL_ON.DAL.Server;
+using Shared;
 
 namespace HDL_ON.Entity
 {
     /// <summary>
     /// 璇诲彇鏈嶅姟鍣ㄧ┖闂翠俊鎭繑鍥炲埌鏁版嵁鍖�
     /// </summary>
-    public class RoomApiPack
+    public class SpatialApiPack
     {
         public List<SpatialInfo> list = new List<SpatialInfo>();
 
@@ -25,154 +27,411 @@
     /// </summary>
     public class SpatialInfo
     {
-        public string roomId = "";
-        public string roomName = "";
-        public string roomImage = "";
-        public string roomType = "";
-        public string parentId = "";
-        public string uid = Guid.NewGuid().ToString();
-
-        public string createTime = "";
-        public string modifyTime = "";
-
-        protected void SaveSpatialInfo()
-        {
-            var pm = new DAL.Server.HttpServerRequest();
-            if (string.IsNullOrEmpty(createTime) && string.IsNullOrEmpty(modifyTime))
-            {
-                pm.AddRoom(new List<SpatialInfo>() { this });
-            }
-            else if (string.IsNullOrEmpty(createTime) && !string.IsNullOrEmpty(modifyTime))
-            {
-                pm.DeleteRoom(new List<string>() { roomId });
-            }
-            else if (!string.IsNullOrEmpty(createTime) && !string.IsNullOrEmpty(modifyTime))
-            {
-                pm.UpdateRoom(new List<SpatialInfo>() { this });
-            }
-        }
-
-        /// <summary>
-        /// 鏇存柊妤煎眰淇℃伅
-        /// </summary>
-        public void UpdateSpatialInfoData()
-        {
-            if (roomType == "ROOM")
-            {
-
-            }
-            else if (roomType == "FLOOR")
-            {
-                var tempFloor = Floor.InsFloor.Floors.Find((obj) => obj.roomId == roomId);
-                if (tempFloor == null)
-                {
-                    Floor.InsFloor.Floors.Add(this as Floor);
-                }
-                else
-                {
-                    tempFloor = this as Floor;
-                }
-                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(Floor.InsFloor.Floors));
-                FileUtils.WriteFileByBytes(Floor.InsFloor.FloorDataSavePath, ssd);
-                MainPage.Log("鏇存柊妤煎眰淇℃伅");
-            }
-        }
-    }
-
-    /// <summary>
-    /// 鎴块棿瀵硅薄
-    /// </summary>
-    [Serializable]
-    public class Floor : SpatialInfo
-    {
-        #region 妤煎眰鏁版嵁鐩稿叧
-        static Floor ins_Floor ;
-        public static Floor InsFloor {
-            get {
-                if(ins_Floor== null)
-                {
-                    ins_Floor = new Floor();
-                }
-                return ins_Floor;
-            }
-        }
-        public string FloorDataSavePath = "FloorsData";
-        /// <summary>
-        /// 妤煎眰鍒楄〃
-        /// </summary>
-        List<Floor> floors;
-        public List<Floor> Floors
+        static SpatialInfo _currentSpatial;
+        public static SpatialInfo CurrentSpatial
         {
             get
             {
+                if (_currentSpatial == null)
+                {
+                    _currentSpatial = new SpatialInfo();
+                }
+                return _currentSpatial;
+            }
+        }
+        public SpatialInfo()
+        {
+        }
+
+        public SpatialInfo(string spatialType)
+        {
+            roomType = "FLOOR";
+            parentId = DB_ResidenceData.Instance.CurrentRegion.id;
+        }
+
+        public string homeId = "";
+        public string roomId = "";
+        public string roomName = "";
+        //public string roomImage = "";
+        public string roomImage = "Classification/Room/Roombg.png";
+        public string roomType = "";
+        public string parentId = "";
+        public string uid = Guid.NewGuid().ToString();
+        public string floorRoomName = "";
+        public string createTime = "";
+        public string modifyTime = "";
+        ///// <summary>
+        ///// 鍒犻櫎鏍囪 20201208锛氬彲娆�:APP鐨勫湪绾垮拰绂荤嚎闂锛屽垰鍒氱‘瀹氫簡锛岀绾挎棤娉曠紪杈戯紝鍙兘鎺у埗
+        ///// 闇�瑕佸垹闄ゆ暟鎹椂锛屾爣璁颁负锛歵rue
+        ///// 鐢变簯绔垹闄ゆ垚鍔熶箣鍚庯紝杩斿洖鏁版嵁鍐嶆竻闄ゆ湰鍦版暟鎹�
+        ///// </summary>
+        //public bool DeleteSign = false;
+
+        /// <summary>
+        /// 鏇存柊绌洪棿淇℃伅
+        /// </summary>
+        /// <param name="spatials">绌洪棿淇℃伅</param>
+        /// <param name="optionType">鎿嶄綔绫诲瀷锛欰DD/UPDATE/DELETE</param>
+        public void UpdateSpatialList(List<SpatialInfo> spatials)
+        {
+            var roomUpdateList = spatials.FindAll((obj) => obj.roomType == "ROOM");
+            var floorUpdateList = spatials.FindAll((obj) => obj.roomType == "FLOOR");
+            CurrentSpatial.DeleteAllRoom();
+            FloorList.Clear();
+            //澶勭悊鎴块棿鍒楄〃
+            if (roomUpdateList != null && roomUpdateList.Count > 0)
+            {
+                foreach (var newRoom in roomUpdateList)
+                {
+                    newRoom.SaveRoomFile();
+                    RoomList.Add(Newtonsoft.Json.JsonConvert.DeserializeObject<Room>(
+                        Newtonsoft.Json.JsonConvert.SerializeObject(newRoom)));
+                }
+            }
+            //妤煎眰鎴块棿鍒楄〃
+            if (floorUpdateList != null && floorUpdateList.Count > 0)
+            {
+                foreach (var updateTemp in floorUpdateList)
+                {
+                    FloorList.Add(updateTemp);
+                }
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(FloorList));
+                Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
+            }
+        }
+
+        #region 妤煎眰鍒楄〃
+        /// <summary>
+        /// 妤煎眰鍒楄〃
+        /// </summary>
+        List<SpatialInfo> floors;
+        /// <summary>
+        /// 妤煎眰鍒楄〃
+        /// </summary>
+        public List<SpatialInfo> FloorList
+        {
+            get
+            {
+                if (MainPage.NoLoginMode)
+                {
+                    if (floors == null)
+                    {
+                        floors = new List<SpatialInfo>();
+                    }
+                    return floors;
+                }
+
                 if (floors == null)
                 {
                     try
                     {
-                        var floorsDataBytes = FileUtils.ReadFile(FloorDataSavePath);
+                        var floorsDataBytes = Common.FileUtlis.Files.ReadFile("FloorsData");
                         if (floorsDataBytes != null)
                         {
                             var floorsDataString = System.Text.Encoding.UTF8.GetString(floorsDataBytes);
                             MainPage.Log(floorsDataString);
-                            floors = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Floor>>(floorsDataString);
-                            if (floors == null)
-                            {
-                                floors = new List<Floor>();
-                            }
+                            floors = Newtonsoft.Json.JsonConvert.DeserializeObject<List<SpatialInfo>>(floorsDataString);
+                        }
+                        if(floors == null)
+                        {
+                            floors = new List<SpatialInfo>();
                         }
                     }
                     catch (Exception ex)
                     {
+                            floors = new List<SpatialInfo>();
                         MainPage.Log($"妤煎眰鏁版嵁鍒濆鍖栧け璐ワ細{ex.Message}");
                     }
                 }
                 return floors;
             }
         }
-
+        /// <summary>
+        /// 鏁版嵁淇濆瓨璺緞
+        /// </summary>
+        string dataSavePath
+        {
+            get
+            {
+                if(roomType == "ROOM")
+                {
+                    return "RoomPath_" + uid;
+                }
+                if(roomType == "FLOOR")
+                {
+                    return "FloorsData"; 
+                }
+                else
+                {
+                    return "SpatialInfo_"+uid;
+                }
+            }
+        }
         /// <summary>
         /// 澧炲姞妤煎眰
         /// </summary>
         /// <param name="floor"></param>
-        public void AddFloor(Floor floor)
+        public string AddFloor(SpatialInfo floor, out SpatialInfo newFloor)
         {
-            ins_Floor.floors.Add(floor);
-            floor.SaveFloorData();
+            var pm = new HttpServerRequest();
+            var revPack = new ResponsePackNew();
+            revPack = pm.AddRoom(new List<SpatialInfo>() { floor });
+            if (revPack.Code == StateCode.SUCCESS)
+            {
+                var revData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<SpatialInfo>>(revPack.Data.ToString());
+                if (revData.Count > 0)
+                {
+                    var addFloor = revData.Find((obj) => obj.uid == floor.uid);
+                    if (addFloor != null)
+                    {
+                        CurrentSpatial.FloorList.Add(addFloor);
+                        floor = addFloor;
+                    }
+                }
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(CurrentSpatial.FloorList));
+                Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
+            }
+            else
+            {
+                Utlis.ShowTip(Language.StringByID(StringId.AddFloorFail) + "\r\nCode:" + revPack.Code);
+            }
+            newFloor = floor;
+            return revPack.Code;
+        }
+        /// <summary>
+        /// 鏇存柊妤煎眰淇℃伅
+        /// </summary>
+        /// <param name="floor"></param>
+        public string UpdateFloor(SpatialInfo floor)
+        {
+            var pm = new HttpServerRequest();
+            var revPack = pm.UpdateRoom(new List<SpatialInfo>() { floor });
+            if (revPack.Code == StateCode.SUCCESS)
+            {
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(FloorList));
+                Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
+            }
+            return revPack.Code;
         }
         /// <summary>
         /// 鍒犻櫎妤煎眰
         /// </summary>
         /// <param name="floor"></param>
-        public void DelFloor(Floor floor)
+        public string DelFloor(string floorId)
         {
-            var tRoom = ins_Floor.floors.Find((obj) => obj.uid == floor.uid);
-            if (tRoom != null)
+            if (string.IsNullOrEmpty( floorId))
+                return "";
+            var pm = new HttpServerRequest();
+            var code = pm.DeleteRoom(new List<string>() { floorId }).Code;
+            if (code == StateCode.SUCCESS)
             {
-                ins_Floor.floors.Remove(floor);
-                floor.modifyTime = "";
+                var tRoom = CurrentSpatial.FloorList.Find((obj) => obj.roomId == floorId);
+                if (tRoom != null)
+                {
+                    CurrentSpatial.FloorList.Remove(tRoom);
+                }
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(FloorList));
+                Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
             }
-            SaveFloorData();
+            else
+            {
+                Utlis.ShowTip(Language.StringByID(StringId.DeleteFloorFail) + "\r\nCode:" + code);
+            }
+            return code;
         }
 
         #endregion
 
-        public Floor()
+        #region 鎴块棿鍒楄〃
+        /// <summary>
+        /// 鎴块棿鍒楄〃
+        /// </summary>
+        List<Room> rooms;
+        /// <summary>
+        /// 鎴块棿鍒楄〃
+        /// </summary>
+        public List<Room> RoomList
         {
-            roomType = "FLOOR";
-            parentId = DB_ResidenceData.residenceData.CurReginID;
+            get
+            {
+                if(MainPage.NoLoginMode )
+                {
+                    if (rooms == null)
+                    {
+                        rooms = new List<Room>();
+                    }
+                    return rooms;
+                }
+                if (rooms == null)
+                {
+                    try
+                    {
+                        rooms = new List<Room> { };
+                        var filePathList = Common.FileUtlis.Files.ReadFiles();
+
+                        foreach (var filePath in filePathList)
+                        {
+                            if (filePath.StartsWith("RoomData_"))
+                            {
+                                var roomDataBytes = Common.FileUtlis.Files.ReadFile(filePath);
+                                var roomDataString = System.Text.Encoding.UTF8.GetString(roomDataBytes);
+                                var room = Newtonsoft.Json.JsonConvert.DeserializeObject<Room>(roomDataString);
+                                if (room != null)
+                                {
+                                    rooms.Add(room);
+                                }
+                            }
+                        }
+                    }
+                    catch (Exception ex)
+                    {
+                        MainPage.Log($"鍔熻兘鏁版嵁鍒濆鍖栧け璐ワ細{ex.Message}");
+                    }
+                }
+                return rooms;
+            }
         }
         /// <summary>
-        /// 淇濆瓨妤煎眰鏁版嵁
+        /// 澧炲姞鎴块棿
         /// </summary>
-        public void SaveFloorData()
+        /// <param name="room"></param>
+        public string AddRoom(Room room,out Room newRoom)
         {
-            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(ins_Floor.floors));
-            FileUtils.WriteFileByBytes(FloorDataSavePath, ssd);
-            MainPage.Log($"Save floor Data");
-            base.SaveSpatialInfo();
+            var pm = new HttpServerRequest();
+            var pack = pm.AddRoom(new List<SpatialInfo>() { room });
+
+            if (pack.Code == StateCode.SUCCESS)
+            {
+                var revData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<SpatialInfo>>(pack.Data.ToString());
+                if (revData != null)
+                {
+                    if (revData.Count > 0)
+                    {
+                        var tempRoom = revData.Find((obj) => obj.uid == room.uid);
+                        if (tempRoom != null)
+                        {
+                            room.roomId = tempRoom.roomId;
+                            CurrentSpatial.RoomList.Add(room);
+                            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(room));
+                            Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
+                        }
+                    }
+                }
+            }
+            newRoom = room;
+            return pack.Code;
+        }
+        /// <summary>
+        /// 鍒犻櫎鎴块棿
+        /// </summary>
+        /// <param name="room"></param>
+        public string DelRoom(Room room)
+        {
+            var pm = new HttpServerRequest();
+            var pack = pm.DeleteRoom(new List<string>() { room.roomId });
+            if (pack.Code == StateCode.SUCCESS)
+            {
+                var tRoom = RoomList.Find((obj) => obj.roomId == room.roomId);
+                if (tRoom != null)
+                {
+                    CurrentSpatial.RoomList.Remove(room);
+                }
+                Common.FileUtlis.Files.DeleteFile(room.dataSavePath);
+            }
+            return pack.Code;
+        }
+        /// <summary>
+        /// 鍒犻櫎鎵�鏈夋埧闂�
+        /// </summary>
+        public void DeleteAllRoom()
+        {
+            for(int i=0;i< RoomList.Count;)
+            {
+                Common.FileUtlis.Files.DeleteFile(RoomList[i].dataSavePath);
+                RoomList.RemoveAt(i);
+            }
+            rooms = null;
         }
 
+        public void Clear()
+        {
+            if (_currentSpatial != null)
+            {
+                if (_currentSpatial.floors != null)
+                {
+                    _currentSpatial.floors.Clear();
+                }
+                if (_currentSpatial.rooms != null)
+                {
+                    _currentSpatial.rooms.Clear();
+                }
+                _currentSpatial = null;
+            }
+        }
+
+        /// <summary>
+        /// 鍒濆鍖栨瘡涓埧闂寸殑鍔熻兘鏁版嵁
+        /// </summary>
+        public void InitRoomListFunctions()
+        {
+            new System.Threading.Thread(() =>
+            {
+                try
+                {
+                    //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹�
+                    foreach (var r in RoomList)
+                    {
+                        InitRoomFuntion(r);
+                    }
+                }
+                catch (Exception ex)
+                {
+                    MainPage.Log($"Init room function error : {ex.Message}");
+                }
+            })
+            { IsBackground = true }.Start();
+        }
+        /// <summary>
+        /// 鍒濆鍖栨埧闂村姛鑳�
+        /// </summary>
+        /// <param name="tempRoom"></param>
+        public void InitRoomFuntion(Room tempRoom)
+        {
+            tempRoom.GetRoomFunctions(true);
+            tempRoom.GetRoomScenes(true);
+        }
+
+        /// <summary>
+        /// 淇濆瓨鎴块棿鏁版嵁鏂囦欢
+        /// </summary>
+        public void SaveRoomFile()
+        {
+            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+            Common.FileUtlis.Files.WriteFileByBytes(dataSavePath, ssd);
+        }
+        /// <summary>
+        /// 鏇存柊鎴块棿鏁版嵁
+        /// </summary>
+        public void UpdataRoomInfo()
+        {
+            new System.Threading.Thread(() =>
+            {
+                var pm = new HttpServerRequest();
+                var pack = pm.UpdateRoom(new List<SpatialInfo>() { this });
+                this.SaveRoomFile();
+                if (pack.Code != StateCode.SUCCESS)
+                {
+                    IMessageCommon.Current.ShowErrorInfoAlter(pack.Code);
+                }
+            })
+            { IsBackground = true }.Start();
+        }
+      
+        #endregion
+
     }
+
+
 
     [Serializable]
     public class Room : SpatialInfo
@@ -182,14 +441,27 @@
             roomType = "ROOM";
             roomName = "Room";
         }
-        public string backgroundImage = "Classification/Room/Roombg.png";
-        public string roomSavePath
+        //public string backgroundImage = "Classification/Room/Roombg.png";
+        public string backgroundImage
         {
             get
             {
-                return "RoomPath_" + uid;
+                if (string.IsNullOrEmpty(roomImage))
+                {
+                    return "Classification/Room/Roombg.png";
+                }
+                else
+                {
+                    return roomImage;
+                }
+            }
+            set
+            {
+                roomImage = value;
             }
         }
+
+
         /// <summary>
         /// 妤煎眰
         /// </summary>
@@ -198,9 +470,9 @@
         {
             get
             {
-                if (Floor.InsFloor.Floors.Count > 0)
+                if (CurrentSpatial.FloorList.Count > 0)
                 {
-                    var f = Floor.InsFloor.Floors.Find((obj) => obj.uid == parentId);
+                    var f = CurrentSpatial.FloorList.Find((obj) => obj.uid == parentId);
                     if (f != null)
                     {
                         return f.roomName + " ";
@@ -210,10 +482,10 @@
             }
         }
 
-        /// <summary>
-        /// 鎴块棿鍔熻兘鍒楄〃
-        /// </summary>
-        List<Function> functions = new List<Function>();
+        ///// <summary>
+        ///// 鎴块棿鍔熻兘鍒楄〃
+        ///// </summary>
+        //List<Function> functions = new List<Function>();
         /// <summary>
         /// 鑾峰彇鎴块棿鍔熻兘鍒楄〃
         /// </summary>
@@ -221,13 +493,13 @@
         {
             if (needRefresh)
             {
-                functions = new List<Function>();
             }
+            var functions = new List<Function>();
             if (functions.Count == 0)
             {
-                foreach (var f in DB_ResidenceData.functionList.GetAllFunction())
+                foreach (var f in FunctionList.List.GetDeviceFunctionList())
                 {
-                    if (f.roomIds.Contains(uid) && uid != null)
+                    if (f.roomIds.Contains(roomId) && roomId != null)
                     {
                         functions.Add(f);
                     }
@@ -235,22 +507,22 @@
             }
             return functions;
         }
-        /// <summary>
-        /// 澧炲姞鎴块棿鍔熻兘
-        /// 鎿嶄綔鐨勬槸缂撳瓨鏁版嵁锛屼笉鐢ㄤ繚瀛�
-        /// </summary>
-        public void AddRoomFunction(Function function)
-        {
-            functions.Add(function);
-        }
-        /// <summary>
-        /// 鍒犻櫎鎴块棿鍔熻兘
-        /// 鎿嶄綔鐨勬槸缂撳瓨鏁版嵁锛屼笉鐢ㄤ繚瀛�
-        /// </summary>
-        public void RemoveRoomFunction(Function function)
-        {
-            functions.Remove(functions.Find((obj) => obj.sid == function.sid));
-        }
+        ///// <summary>
+        ///// 澧炲姞鎴块棿鍔熻兘
+        ///// 鎿嶄綔鐨勬槸缂撳瓨鏁版嵁锛屼笉鐢ㄤ繚瀛�
+        ///// </summary>
+        //public void AddRoomFunction(Function function)
+        //{
+        //    functions.Add(function);
+        //}
+        ///// <summary>
+        ///// 鍒犻櫎鎴块棿鍔熻兘
+        ///// 鎿嶄綔鐨勬槸缂撳瓨鏁版嵁锛屼笉鐢ㄤ繚瀛�
+        ///// </summary>
+        //public void RemoveRoomFunction(Function function)
+        //{
+        //    functions.Remove(functions.Find((obj) => obj.sid == function.sid));
+        //}
         /// <summary>
         /// 鎴块棿鍦烘櫙鍒楄〃
         /// </summary>
@@ -267,9 +539,9 @@
             }
             if (scenes.Count == 0)
             {
-                foreach (var s in DB_ResidenceData.functionList.scenes)
+                foreach (var s in FunctionList.List.scenes)
                 {
-                    if (s.roomIds.Contains(uid) && uid != null)
+                    if (s.roomIds.Contains(roomId) && roomId != null)
                     {
                         scenes.Add(s);
                     }
@@ -294,16 +566,6 @@
         public void RemoveRoomScene(Scene scene)
         {
             scenes.Remove(scenes.Find((obj) => obj.sid == scene.sid));
-        }
-        /// <summary>
-        /// 淇濆瓨鎴块棿鏁版嵁
-        /// </summary>
-        public void SaveRoomData()
-        {
-            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-            FileUtils.WriteFileByBytes(roomSavePath, ssd);
-            MainPage.Log($"Save Room Data {roomName} : {this.uid}");
-            base.SaveSpatialInfo();
         }
     }
   

--
Gitblit v1.8.0