From d87400af518ebc9274f4447f06476959c3aa5102 Mon Sep 17 00:00:00 2001 From: xm <1271024303@qq.com> Date: 星期二, 14 七月 2020 16:29:42 +0800 Subject: [PATCH] Merge branch 'dev-tzy' into dev-2020xm --- ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs | 422 +++++++++++++++++++++++++++++----------------------- 1 files changed, 236 insertions(+), 186 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs index 75af7bc..38c531b 100755 --- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs +++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlRoomLogic.cs @@ -61,18 +61,20 @@ this.dicRooms.Clear(); //妫�娴嬫垜鐨勫枩鐖辫繖涓埧闂村璞� this.CheckLoveRoom(); - - foreach (var roomId in Config.Instance.Home.ListRooms) + + var listFile = HdlFileLogic.Current.GetRootPathListFile(); + foreach (var fileName in listFile) { - //浠庢枃浠堕噷闈㈣幏鍙栨埧闂村璞� - var room = this.GetRoomByFilePath($"Room_{roomId}.json"); - if (room != null) + if (fileName.StartsWith("Room_") == true) { - this.dicRooms[room.Id] = (room); + //浠庢枃浠堕噷闈㈣幏鍙栨埧闂村璞� + var room = this.GetRoomByFilePath(fileName); + if (room != null) + { + this.dicRooms[room.Id] = (room); + } } } - //璁剧疆褰撳墠妤煎眰鐨処D - Config.Instance.Home.SetCurrentFloorId(); //椤轰究鍒锋柊鍦烘櫙 HdlSceneLogic.Current.ReFreshByLocal(); //鍒锋柊鎴块棿瑙嗗浘鍒楄〃 @@ -84,17 +86,13 @@ /// </summary> public void RefreshAllRoomByLocation() { - var homeTemp = Config.Instance.Home; - homeTemp.ListRooms.Clear(); - - var listFile = Global.FileListByHomeId(); + var listFile = HdlFileLogic.Current.GetRootPathListFile(); //鎴戠殑鍠滅埍鐨勬埧闂村繀椤昏鍦ㄧ0浣嶆墠琛� string fRoom = "Room_Favorite.json"; if (listFile.Contains(fRoom) == true) { listFile.Remove(fRoom); - homeTemp.ListRooms.Add("Favorite"); } var listRoomFile = new List<string>(); @@ -103,7 +101,6 @@ if (fileName.StartsWith("Room_")) { string roomId = fileName.Replace("Room_", string.Empty).Replace(".json", string.Empty); - homeTemp.ListRooms.Add(roomId); listRoomFile.Add(fileName); } } @@ -117,8 +114,7 @@ this.CheckAdminFloorData(listRoomFile); } - homeTemp.Save(false); - InitAllRoom(); + this.InitAllRoom(); } /// <summary> @@ -128,7 +124,7 @@ { Application.RunOnMainThread(() => { - MainPage.ListRoomViewFrom.Instance?.RefreshListRoom(); + MainPage.LeftListRoomViewFrom.Instance?.RefreshListRoom(); }); } @@ -215,15 +211,12 @@ /// <param name="rorefreshRoomViewom">鏄惁鍒锋柊鎴块棿瑙嗗浘鍒楄〃鐣岄潰</param> public void AddRoom(Room room, bool refreshRoomView = true) { - if (Global.IsExistsByHomeId(room.FileName) == true - || Config.Instance.Home.ListRooms.Contains(room.Id) == true) + if (Global.IsExistsByHomeId(room.FileName) == true) { return; } //娣诲姞鍒扮紦瀛� this.dicRooms[room.Id] = room; - //鎶婃埧闂碔D娣诲姞鍒颁綇瀹� - Config.Instance.Home.AddRoomId(room.Id); //鐢熸垚鏂囦欢 room.Save(); //澶囦唤 @@ -243,9 +236,21 @@ /// 鍒犻櫎鎴块棿 /// </summary> /// <param name="roomId">鎴块棿ID</param> + /// <param name="refreshLeftView">鏄惁鍒锋柊宸︽粦鐣岄潰(姝ゅ彉閲忕洰鍓嶆槸缁欏垹闄ゅ叏閮ㄦ埧闂寸敤鐨�)</param> /// <returns></returns> - public void RemoveRoom(string roomId) + public void RemoveRoom(string roomId, bool refreshLeftView = true) { + if (this.NowMainPageRoom != null && this.NowMainPageRoom.Id == roomId) + { + //褰撳垹闄ょ殑鏄富椤电殑鎴块棿鐨勬椂鍊� + this.NowMainPageRoom = this.GetLoveRoom(); + } + if (this.NowCategoryRoom != null && this.NowCategoryRoom.Id == roomId) + { + //褰撳垹闄ょ殑鏄垎绫荤殑鎴块棿鐨勬椂鍊� + this.NowCategoryRoom = this.GetLoveRoom(); + } + //鏍规嵁鎴块棿Id锛岃幏鍙栨埧闂村璞� var room = this.GetRoomById(roomId); if (room == null) @@ -279,8 +284,6 @@ } loveRoom.Save(false); } - - Config.Instance.Home.RemoveRoomId(roomId); this.dicRooms.Remove(roomId); string roomFilePath = room.FileName; @@ -293,9 +296,31 @@ //鏍规嵁鎴块棿ID,绉婚櫎鎸囧畾鐨勭湡瀹炵墿鐞嗚澶囩殑鎵�灞炴埧闂磋褰� Common.LocalDevice.Current.DeleteRealDeviceByRoomId(roomId); + if (refreshLeftView == true) + { + //HdlAutoBackupLogic.DeleteFile(roomFilePath); + //鍒锋柊鎴块棿瑙嗗浘鍒楄〃 + this.RefreshRoomListView(); + } + } - //鍒锋柊鎴块棿瑙嗗浘鍒楄〃 - this.RefreshRoomListView(); + /// <summary> + /// 鍒犻櫎鍏ㄩ儴鐨勬埧闂� + /// </summary> + public void DeleteAllRoom() + { + var listRoomId = new List<string>(); + foreach (var room in this.dicRooms.Values) + { + if (room.IsLove == false) + { + listRoomId.Add(room.Id); + } + } + foreach (var roomId in listRoomId) + { + this.RemoveRoom(roomId, false); + } } #endregion @@ -357,7 +382,7 @@ public string GetRoomNameByDevice(CommonDevice device) { var room = this.GetRoomByDevice(device); - return this.GetFloorRoomName(room); + return this.GetRoomName(room); } /// <summary> @@ -365,7 +390,7 @@ /// </summary> /// <returns>鎴块棿鍚�</returns> /// <param name="room">鎴块棿瀵硅薄</param> - public string GetFloorRoomName(Room room) + public string GetRoomName(Room room) { if (room == null) { @@ -466,7 +491,7 @@ } } } - return listRoom; + return this.SortRoom(listRoom); } /// <summary> @@ -480,36 +505,7 @@ { listRoom.Add(room); } - return listRoom; - } - - /// <summary> - /// 鑾峰彇褰撳墠妤煎眰鐨勬埧闂村悕绉� - /// </summary> - /// <param name="id"></param> - /// <returns></returns> - public List<string> GetRoomNamesByFloorId(string id) - { - var listName = new List<string>(); - if (Config.Instance.Home.FloorDics.Count == 0) - { - //娌℃湁妤煎眰 - foreach (var room in this.dicRooms.Values) - { - listName.Add(room.Name); - } - } - else - { - foreach (var room in this.dicRooms.Values) - { - if (room.FloorId == id) - { - listName.Add(room.Name); - } - } - } - return listName; + return this.SortRoom(listRoom); } /// <summary> @@ -541,17 +537,10 @@ } } } + listRoom = this.SortRoom(listRoom); + listRoom.Insert(0, GetLoveRoom()); return listRoom; - } - - /// <summary> - /// 鑾峰彇褰撳墠妤煎眰鐨勬埧闂�(鎷兼帴浜嗐�愬父鐢ㄣ�戝湪绗竴浣�) - /// </summary> - /// <returns></returns> - public List<Room> GetRoomsByCurrentFloorIdAppendLoveRoom() - { - return this.GetRoomsByFloorIdAppendLoveRoom(Config.Instance.Home.CurrentFloorId); } #endregion @@ -574,7 +563,7 @@ //绉婚櫎鎴戠殑鍠滅埍 this.DeleteLoveDevice(device); //璁惧鏀瑰彉鎴块棿鐨勮瘽,涓婚〉闇�瑕侀噸鏂板埛鏂� - UserView.UserPage.Instance.RefreshForm = true; + UserView.UserPage.Instance.RefreshAllForm = true; return; } //鎴块棿鏄惁淇敼 @@ -592,7 +581,7 @@ this.AddDevice(room, device, saveRealRoom); } //璁惧鏀瑰彉鎴块棿鐨勮瘽,涓婚〉闇�瑕侀噸鏂板埛鏂� - UserView.UserPage.Instance.RefreshForm = true; + UserView.UserPage.Instance.RefreshAllForm = true; } /// <summary> @@ -609,25 +598,6 @@ return true; } return false; - } - - /// <summary> - /// 鑾峰彇鎴块棿鎵�鍦ㄥ尯鍩� - /// 妤煎眰,鎴块棿鍚� - /// </summary> - /// <returns></returns> - public string GetZoneName(Room i_room) - { - if (string.IsNullOrEmpty(i_room.FloorId)) - { - return i_room.Name; - } - var floorName = HdlResidenceLogic.Current.GetFloorNameById(i_room.FloorId); - if (floorName == null) - { - return i_room.Name; - } - return $"{floorName}锛寋i_room.Name}"; } #endregion @@ -684,6 +654,8 @@ //淇濆瓨鍒版湰鍦� loveRoom.ListDevice.Add(mainkeys); loveRoom.Save(); + //娣诲姞鏀惰棌璁惧鏃�,闇�瑕佸埛鏂颁富椤� + UserView.UserPage.Instance.RefreshAllForm = true; } } } @@ -747,6 +719,8 @@ loveRoom.Save(); //鏇存敼鑷姩澶囦唤 HdlAutoBackupLogic.AddOrEditorFile(loveRoom.FileName); + //娣诲姞鏀惰棌璁惧鏃�,闇�瑕佸埛鏂颁富椤� + UserView.UserPage.Instance.RefreshAllForm = true; } } @@ -935,85 +909,87 @@ { i_floorKeys = string.Empty; } - Dictionary<string, List<string>> dicAllSort = new Dictionary<string, List<string>>(); - //璇诲彇鎴块棿椤哄簭 - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.RoomSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) - { - dicAllSort = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, List<string>>>(strData); - } - - var listRoomSort = new List<string>(); - if (dicAllSort.ContainsKey(i_floorKeys) == true) - { - listRoomSort = dicAllSort[i_floorKeys]; - } - else - { - dicAllSort[i_floorKeys] = listRoomSort; - } - - var dicRoom = new Dictionary<string, Common.Room>(); + var listRoom = new List<Room>(); foreach (var room in this.dicRooms.Values) { - if (room.FloorId != i_floorKeys && i_floorKeys != string.Empty) + if (room.FloorId != i_floorKeys && i_floorKeys != string.Empty + || room.IsLove == true) { - //涓嶆槸鍚屼竴涓ゼ灞� + //涓嶆槸鍚屼竴涓ゼ灞�,涓嶈鎴戠殑鍠滅埍 continue; - } - if (room.IsLove == true) - { - //涓嶈鎴戠殑鍠滅埍 - continue; - } - if (listRoomSort.Contains(room.Id) == false) - { - //鏂版坊鍔犵殑鎴块棿 - listRoomSort.Add(room.Id); } if (getShard == false && room.IsSharedRoom == true) { //涓嶈鍒嗕韩鐨勬埧闂� continue; } - dicRoom[room.Id] = room; + listRoom.Add(room); } - - var listSortRoom = new List<Room>(); - for (int i = 0; i < listRoomSort.Count; i++) - { - if (dicRoom.ContainsKey(listRoomSort[i]) == true) - { - listSortRoom.Add(dicRoom[listRoomSort[i]]); - } - } - - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, dicAllSort); - return listSortRoom; + return this.SortRoom(listRoom); } /// <summary> - /// 淇濆瓨鎴块棿鐨勯『搴� + /// 鎺掑簭鎴块棿瀵硅薄 /// </summary> - /// <param name="i_floorKeys">妤煎眰涓婚敭</param> - /// <param name="listSort">鎴块棿椤哄簭(鎴块棿鐨勪富閿�)</param> - public void SaveRoomSort(string i_floorKeys, List<string> listSort) + /// <param name="listRoom"></param> + /// <returns></returns> + public List<Room> SortRoom(List<Room> listRoom) { - Dictionary<string, List<string>> dicAllSort = new Dictionary<string, List<string>>(); - //璇诲彇鎴块棿椤哄簭 - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.RoomSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) + //浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + var listName = new List<string>(); + foreach (var room in listRoom) { - dicAllSort = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, List<string>>>(strData); + listName.Add(room.Name); } + int numberLength = this.GetNumberMaxLength(listName); - //淇濆瓨椤哄簭 - dicAllSort[i_floorKeys] = listSort; - UserCenterLogic.SaveFileContent(fullName, dicAllSort); - dicAllSort.Clear(); + var listSort = new List<string[]>(); + foreach (var room in listRoom) + { + var strArry = new string[2]; + strArry[0] = room.Id; + strArry[1] = string.Empty; + + string value = string.Empty; + foreach (var c in room.Name) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //濡傛灉鎴块棿鍚嶅瓧甯︽湁鏁板瓧鐨勮瘽,鍒欏乏杈瑰姞闆�,鍥犱负杩欓噷鏈変釜鎺掑簭鐨勯棶棰� + strArry[1] += value.PadLeft(numberLength, '0'); + value = string.Empty; + } + strArry[1] += c.ToString(); + } + if (value != string.Empty) + { + //浠ユ暟瀛楃粨灏剧殑璇� + strArry[1] += value.PadLeft(numberLength, '0'); + } + listSort.Add(strArry); + } + //鎺掑簭 + listSort.Sort((obj1, obj2) => + { + if (obj1[1].CompareTo(obj2[1]) > 0) + { + return 1; + } + return -1; + }); + var listSortRoom = new List<Room>(); + foreach (var strArry in listSort) + { + var room = this.GetRoomById(strArry[0]); + listSortRoom.Add(room); + } + return listSortRoom; } /// <summary> @@ -1022,46 +998,66 @@ /// <returns></returns> public Dictionary<string, string> GetFloorSortList() { - //璇诲彇妤煎眰椤哄簭 - var listFloorSort = new List<string>(); - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.FloorSortFile); - var strData = UserCenterLogic.LoadFileContent(fullName); - if (strData != null) + //娌℃湁妤煎眰 + if (Config.Instance.Home.FloorDics.Count == 0) { - listFloorSort = Newtonsoft.Json.JsonConvert.DeserializeObject<List<string>>(strData); + return new Dictionary<string, string>(); } - foreach (string keys in Common.Config.Instance.Home.FloorDics.Keys) + //浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + var listName = new List<string>(); + foreach (var floorName in Config.Instance.Home.FloorDics.Values) { - if (listFloorSort.Contains(keys) == false) - { - //鏂版坊鍔犵殑妤煎眰 - listFloorSort.Add(keys); - } + listName.Add(floorName); } + int numberLength = this.GetNumberMaxLength(listName); + var listSort = new List<string[]>(); + foreach (var floorId in Config.Instance.Home.FloorDics.Keys) + { + var strArry = new string[2]; + strArry[0] = floorId; + strArry[1] = string.Empty; + + string value = string.Empty; + string floorName = Config.Instance.Home.FloorDics[floorId]; + foreach (var c in floorName) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //濡傛灉鎴块棿鍚嶅瓧甯︽湁鏁板瓧鐨勮瘽,鍒欏乏杈瑰姞闆�,鍥犱负杩欓噷鏈変釜鎺掑簭鐨勯棶棰� + strArry[1] += value.PadLeft(numberLength, '0'); + value = string.Empty; + } + strArry[1] += c.ToString(); + } + if (value != string.Empty) + { + //浠ユ暟瀛楃粨灏剧殑璇� + strArry[1] += value.PadLeft(numberLength, '0'); + } + listSort.Add(strArry); + } + //妤煎眰鎺掑簭 + listSort.Sort((obj1, obj2) => + { + if (obj1[1].CompareTo(obj2[1]) > 0) + { + return 1; + } + return -1; + }); var dic = new Dictionary<string, string>(); - for (int i = 0; i < listFloorSort.Count; i++) + foreach (var strArry in listSort) { - if (Config.Instance.Home.FloorDics.ContainsKey(listFloorSort[i]) == true) - { - dic[listFloorSort[i]] = Config.Instance.Home.FloorDics[listFloorSort[i]]; - } + dic[strArry[0]] = Config.Instance.Home.FloorDics[strArry[0]]; } - - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, listFloorSort); return dic; - } - - /// <summary> - /// 淇濆瓨妤煎眰鐨勯『搴� - /// </summary> - /// <param name="listSort">妤煎眰鐨勪富閿�</param> - public void SaveFloorSort(List<string> listSort) - { - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.FloorSortFile); - //淇濆瓨椤哄簭 - UserCenterLogic.SaveFileContent(fullName, listSort); } #endregion @@ -1094,24 +1090,78 @@ #region 鈻� 涓�鑸柟娉昣__________________________ /// <summary> + /// 鑾峰彇鎴块棿鎬绘暟 + /// </summary> + /// <returns></returns> + public int GetRoomCount() + { + return this.dicRooms.Count; + } + + /// <summary> /// 妫�娴嬫垜鐨勫枩鐖辫繖涓埧闂村璞� /// </summary> private void CheckLoveRoom() { - if (Config.Instance.Home.ListRooms.Contains("Favorite") == false) + if (this.dicRooms.ContainsKey("Favorite") == true) + { + return; + } + //璇诲彇鏈湴鎴戠殑鍠滅埍鏂囦欢 + string favoriteFile = System.IO.Path.Combine(Common.Config.Instance.FullPath, "Room_Favorite.json"); + var fileContent = HdlFileLogic.Current.ReadFileTextContent(favoriteFile); + if (fileContent != null) + { + var love = Newtonsoft.Json.JsonConvert.DeserializeObject<Room>(fileContent); + this.dicRooms["Favorite"] = love; + } + else { //榛樿娣诲姞鍠滅埍鐨勬埧闂�--绂佹淇敼鎴块棿鍚� var love = new Room { Name = Language.StringByID(R.MyInternationalizationString.Favorite), BackgroundImage = "RoomIcon/0.jpg", Id = "Favorite" }; love.Save(false); - //娣诲姞鍒癶ouse 鎴块棿璺緞鍒楄〃 - var currentHome = Config.Instance.Home; - currentHome.ListRooms.Insert(0, love.Id); - currentHome.Save(false); - this.dicRooms["Favorite"] = love; } } + /// <summary> + /// 浠庝竴鍫嗘枃瀛椾腑,鑾峰彇杩欎竴鍫嗘枃瀛楅噷闈㈡暟瀛楀瓧绗︿覆鐨勬渶闀块暱搴� + /// </summary> + /// <param name="listText"></param> + /// <returns></returns> + private int GetNumberMaxLength(List<string> listText) + { + int maxLength = 0; + foreach (var text in listText) + { + string value = string.Empty; + foreach (var c in text) + { + if (char.IsNumber(c) == true) + { + //鏁板瓧 + value += c.ToString(); + continue; + } + else if (value != string.Empty) + { + //鍒ゆ柇鏁板瓧闀垮害 + if (maxLength <= value.Length) + { + maxLength = value.Length; + } + value = string.Empty; + } + } + //鍒ゆ柇鏁板瓧闀垮害 + if (maxLength <= value.Length) + { + maxLength = value.Length; + } + } + return maxLength; + } + #endregion } } -- Gitblit v1.8.0