From 98e49c0dd42840a094837f7acae532bc237a719a Mon Sep 17 00:00:00 2001
From: yangyin <1850366751@qq.com>
Date: 星期二, 20 八月 2024 15:42:37 +0800
Subject: [PATCH] Merge branch 'master' of http://47.103.154.90:83/r/HStation/XHS.V1.0

---
 Service/HStation.Service.Revit.Core/04-service/01-json/RevitJsonHelper.cs |  699 +++++++++++++++++++++++++++++++++------------------------
 1 files changed, 404 insertions(+), 295 deletions(-)

diff --git a/Service/HStation.Service.Revit.Core/04-service/01-json/RevitJsonHelper.cs b/Service/HStation.Service.Revit.Core/04-service/01-json/RevitJsonHelper.cs
index 4e47512..f1b1b73 100644
--- a/Service/HStation.Service.Revit.Core/04-service/01-json/RevitJsonHelper.cs
+++ b/Service/HStation.Service.Revit.Core/04-service/01-json/RevitJsonHelper.cs
@@ -1,4 +1,6 @@
-锘縩amespace HStation.Service
+锘縰sing System.Transactions;
+
+namespace HStation.Service
 {
     /// <summary>
     /// Revit Json杈呭姪绫�
@@ -42,18 +44,24 @@
                                 reservoir.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 reservoir.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 reservoir.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                reservoir.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     reservoir.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                reservoir.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                reservoir.Position = reservoir.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
                                 {
                                     reservoir.PoolElev = poolElev;
@@ -79,18 +87,23 @@
                                 tank.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 tank.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 tank.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                tank.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     tank.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                tank.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                tank.Position = tank.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
                                 {
                                     tank.PoolElev = poolElev;
@@ -132,18 +145,23 @@
                                 waterbox.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 waterbox.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 waterbox.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                waterbox.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     waterbox.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                waterbox.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                waterbox.Position = waterbox.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
                                 {
                                     waterbox.PoolElev = poolElev;
@@ -185,18 +203,23 @@
                                 junction.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 junction.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 junction.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                junction.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     junction.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                junction.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                junction.Position = junction.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     junction.Elev = elev;
@@ -222,18 +245,23 @@
                                 elbow.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 elbow.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 elbow.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                elbow.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     elbow.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                elbow.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                elbow.Position = elbow.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     elbow.Elev = elev;
@@ -259,18 +287,23 @@
                                 threelink.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 threelink.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 threelink.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                threelink.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     threelink.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                threelink.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                threelink.Position = threelink.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     threelink.Elev = elev;
@@ -296,18 +329,23 @@
                                 fourlink.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 fourlink.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 fourlink.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                fourlink.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     fourlink.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                fourlink.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                fourlink.Position = fourlink.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     fourlink.Elev = elev;
@@ -333,18 +371,23 @@
                                 meter.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 meter.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 meter.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                meter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     meter.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                meter.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                meter.Position = meter.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     meter.Elev = elev;
@@ -370,18 +413,23 @@
                                 flowmeter.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 flowmeter.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 flowmeter.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                flowmeter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     flowmeter.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                flowmeter.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                flowmeter.Position = flowmeter.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     flowmeter.Elev = elev;
@@ -407,18 +455,23 @@
                                 pressmeter.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 pressmeter.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 pressmeter.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                pressmeter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     pressmeter.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                pressmeter.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                pressmeter.Position = pressmeter.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     pressmeter.Elev = elev;
@@ -444,18 +497,23 @@
                                 blunthead.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 blunthead.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 blunthead.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                blunthead.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     blunthead.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                blunthead.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                blunthead.Position = blunthead.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     blunthead.Elev = elev;
@@ -481,18 +539,23 @@
                                 nozzle.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 nozzle.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 nozzle.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                nozzle.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     nozzle.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                nozzle.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                nozzle.Position = nozzle.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     nozzle.Elev = elev;
@@ -522,18 +585,23 @@
                                 hydrant.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 hydrant.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 hydrant.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                hydrant.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
                                 if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
                                 {
                                     hydrant.Quality = quality;
                                 }
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var centerPoint = linkList.GetCenterPoint();
-                                hydrant.Position = new Model.RevitPosition()
-                                {
-                                    X = centerPoint.X,
-                                    Y = centerPoint.Y,
-                                    Z = centerPoint.Z
-                                };
+                                hydrant.Position = hydrant.ConnectList.GetCenterPosition();
                                 if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
                                 {
                                     hydrant.Elev = elev;
@@ -550,148 +618,6 @@
                                 model.Hydrants.Add(hydrant);
                             }
                             break;
-                        case RevitJsonCatalog.Pipe:
-                            {
-                                var pipe = new Model.RevitPipe();
-                                pipe.Id = jobject[RevitJsonProp.Id].ToString();
-                                pipe.Code = jobject[RevitJsonProp.Code].ToString();
-                                if (string.IsNullOrEmpty(pipe.Code))
-                                {
-                                    pipe.Code = pipe.Id;
-                                }
-                                pipe.Name = jobject[RevitJsonProp.Name].ToString();
-                                pipe.ModelType = jobject[RevitJsonProp.ModelType].ToString();
-                                pipe.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
-                                pipe.Description = jobject[RevitJsonProp.Description].ToString();
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var startLinker = linkList.GetStartLinker();
-                                var endLinker = linkList.GetEndLinker();
-                                pipe.StartCode = startLinker.ConnectId;
-                                pipe.EndCode = endLinker.ConnectId;
-                                pipe.StartPosition = new Model.RevitPosition()
-                                {
-                                    X = startLinker.Point.X,
-                                    Y = startLinker.Point.Y,
-                                    Z = startLinker.Point.Z
-                                };
-                                pipe.EndPosition = new Model.RevitPosition()
-                                {
-                                    X = endLinker.Point.X,
-                                    Y = endLinker.Point.Y,
-                                    Z = endLinker.Point.Z
-                                };
-                                pipe.LinkStatus = jobject[RevitJsonProp.LinkStatusPipe].ToString();
-                                if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
-                                {
-                                    pipe.StartElev = startElev;
-                                }
-                                if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
-                                {
-                                    pipe.EndElev = endElev;
-                                }
-                                if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
-                                {
-                                    pipe.StartQuality = startQuality;
-                                }
-                                if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
-                                {
-                                    pipe.EndQuality = endQuality;
-                                }
-
-                                if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
-                                {
-                                    pipe.Length = length;
-                                }
-                                if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
-                                {
-                                    pipe.Diameter = diameter;
-                                }
-                                else if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
-                                {
-                                    pipe.Diameter = internalDiameter;
-                                }
-                                if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
-                                {
-                                    pipe.MinorLoss = minorLoss;
-                                }
-                                if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
-                                {
-                                    pipe.Roughness = roughness;
-                                }
-                                model.Pipes.Add(pipe);
-                            }
-                            break;
-                        case RevitJsonCatalog.Translation:
-                            {
-                                var translation = new Model.RevitTranslation();
-                                translation.Id = jobject[RevitJsonProp.Id].ToString();
-                                translation.Code = jobject[RevitJsonProp.Code].ToString();
-                                if (string.IsNullOrEmpty(translation.Code))
-                                {
-                                    translation.Code = translation.Id;
-                                }
-                                translation.Name = jobject[RevitJsonProp.Name].ToString();
-                                translation.ModelType = jobject[RevitJsonProp.ModelType].ToString();
-                                translation.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
-                                translation.Description = jobject[RevitJsonProp.Description].ToString();
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var startLinker = linkList.GetStartLinker();
-                                var endLinker = linkList.GetEndLinker();
-                                translation.StartCode = startLinker.ConnectId;
-                                translation.EndCode = endLinker.ConnectId;
-                                translation.StartPosition = new Model.RevitPosition()
-                                {
-                                    X = startLinker.Point.X,
-                                    Y = startLinker.Point.Y,
-                                    Z = startLinker.Point.Z
-                                };
-                                translation.EndPosition = new Model.RevitPosition()
-                                {
-                                    X = endLinker.Point.X,
-                                    Y = endLinker.Point.Y,
-                                    Z = endLinker.Point.Z
-                                };
-                                translation.LinkStatus = jobject[RevitJsonProp.LinkStatusPipe].ToString();
-                                if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
-                                {
-                                    translation.StartElev = startElev;
-                                }
-                                if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
-                                {
-                                    translation.EndElev = endElev;
-                                }
-                                if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
-                                {
-                                    translation.StartQuality = startQuality;
-                                }
-                                if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
-                                {
-                                    translation.EndQuality = endQuality;
-                                }
-
-                                if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
-                                {
-                                    translation.Length = length;
-                                }
-                                if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
-                                {
-                                    translation.Diameter = diameter;
-                                }
-                                else if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
-                                {
-                                    translation.Diameter = internalDiameter;
-                                }
-                                if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
-                                {
-                                    translation.MinorLoss = minorLoss;
-                                }
-                                if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
-                                {
-                                    translation.Roughness = roughness;
-                                }
-                                model.Translations.Add(translation);
-                            }
-                            break;
                         case RevitJsonCatalog.Exchanger:
                             {
                                 var exchanger = new Model.RevitExchanger();
@@ -705,23 +631,24 @@
                                 exchanger.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 exchanger.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 exchanger.Description = jobject[RevitJsonProp.Description].ToString();
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var startLinker = linkList.GetStartLinker();
-                                var endLinker = linkList.GetEndLinker();
-                                exchanger.StartCode = startLinker.ConnectId;
-                                exchanger.EndCode = endLinker.ConnectId;
-                                exchanger.StartPosition = new Model.RevitPosition()
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                exchanger.ConnectList = connectList?.Select(x => new Model.RevitConnect()
                                 {
-                                    X = startLinker.Point.X,
-                                    Y = startLinker.Point.Y,
-                                    Z = startLinker.Point.Z
-                                };
-                                exchanger.EndPosition = new Model.RevitPosition()
-                                {
-                                    X = endLinker.Point.X,
-                                    Y = endLinker.Point.Y,
-                                    Z = endLinker.Point.Z
-                                };
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+                                var startConnect = exchanger.ConnectList.GetStartConnect();
+                                var endConnect = exchanger.ConnectList.GetEndConnect();
+                                exchanger.StartCode = startConnect.Id;
+                                exchanger.EndCode = endConnect.Id;
+                                exchanger.StartPosition = startConnect.Position;
+                                exchanger.EndPosition = endConnect.Position;
                                 exchanger.LinkStatus = jobject[RevitJsonProp.LinkStatusPipe].ToString();
                                 if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
                                 {
@@ -760,7 +687,187 @@
                                 {
                                     exchanger.Roughness = roughness;
                                 }
+                                if (exchanger.Length <= 0)
+                                {
+                                    exchanger.Length = exchanger.StartPosition.Distance(exchanger.EndPosition);
+                                }
+                                if (exchanger.Diameter < 0.1)
+                                {
+                                    exchanger.Diameter = 0.1;
+                                }
+                                if (exchanger.Roughness < 0.1)
+                                {
+                                    exchanger.Roughness = 0.1;
+                                }
                                 model.Exchangers.Add(exchanger);
+                            }
+                            break;
+                        case RevitJsonCatalog.Pipe:
+                            {
+                                var pipe = new Model.RevitPipe();
+                                pipe.Id = jobject[RevitJsonProp.Id].ToString();
+                                pipe.Code = jobject[RevitJsonProp.Code].ToString();
+                                if (string.IsNullOrEmpty(pipe.Code))
+                                {
+                                    pipe.Code = pipe.Id;
+                                }
+                                pipe.Name = jobject[RevitJsonProp.Name].ToString();
+                                pipe.ModelType = jobject[RevitJsonProp.ModelType].ToString();
+                                pipe.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
+                                pipe.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                pipe.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+                                var startConnect = pipe.ConnectList.GetStartConnect();
+                                var endConnect = pipe.ConnectList.GetEndConnect();
+                                pipe.StartCode = startConnect.Id;
+                                pipe.EndCode = endConnect.Id;
+                                pipe.StartPosition = startConnect.Position;
+                                pipe.EndPosition = endConnect.Position;
+                                pipe.LinkStatus = jobject[RevitJsonProp.LinkStatusPipe].ToString();
+                                if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
+                                {
+                                    pipe.StartElev = startElev;
+                                }
+                                if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
+                                {
+                                    pipe.EndElev = endElev;
+                                }
+                                if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
+                                {
+                                    pipe.StartQuality = startQuality;
+                                }
+                                if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
+                                {
+                                    pipe.EndQuality = endQuality;
+                                }
+
+                                if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
+                                {
+                                    pipe.Length = length;
+                                }
+                                if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
+                                {
+                                    pipe.Diameter = diameter;
+                                }
+                                else if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
+                                {
+                                    pipe.Diameter = internalDiameter;
+                                }
+                                if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
+                                {
+                                    pipe.MinorLoss = minorLoss;
+                                }
+                                if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
+                                {
+                                    pipe.Roughness = roughness;
+                                }
+                                if (pipe.Length <= 0)
+                                {
+                                    pipe.Length = pipe.StartPosition.Distance(pipe.EndPosition);
+                                }
+                                if (pipe.Diameter < 0.1)
+                                {
+                                    pipe.Diameter = 0.1;
+                                }
+                                if (pipe.Roughness < 0.1)
+                                {
+                                    pipe.Roughness = 0.1;
+                                }
+                                model.Pipes.Add(pipe);
+                            }
+                            break;
+                        case RevitJsonCatalog.Translation:
+                            {
+                                var translation = new Model.RevitTranslation();
+                                translation.Id = jobject[RevitJsonProp.Id].ToString();
+                                translation.Code = jobject[RevitJsonProp.Code].ToString();
+                                if (string.IsNullOrEmpty(translation.Code))
+                                {
+                                    translation.Code = translation.Id;
+                                }
+                                translation.Name = jobject[RevitJsonProp.Name].ToString();
+                                translation.ModelType = jobject[RevitJsonProp.ModelType].ToString();
+                                translation.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
+                                translation.Description = jobject[RevitJsonProp.Description].ToString();
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                translation.ConnectList = connectList?.Select(x => new Model.RevitConnect()
+                                {
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+                                var startConnect = translation.ConnectList.GetStartConnect();
+                                var endConnect = translation.ConnectList.GetEndConnect();
+                                translation.StartCode = startConnect.Id;
+                                translation.EndCode = endConnect.Id;
+                                translation.StartPosition = startConnect.Position;
+                                translation.EndPosition = endConnect.Position;
+                                translation.LinkStatus = jobject[RevitJsonProp.LinkStatusPipe].ToString();
+                                if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
+                                {
+                                    translation.StartElev = startElev;
+                                }
+                                if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
+                                {
+                                    translation.EndElev = endElev;
+                                }
+                                if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
+                                {
+                                    translation.StartQuality = startQuality;
+                                }
+                                if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
+                                {
+                                    translation.EndQuality = endQuality;
+                                }
+
+                                if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
+                                {
+                                    translation.Length = length;
+                                }
+                                if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
+                                {
+                                    translation.Diameter = diameter;
+                                }
+                                else if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
+                                {
+                                    translation.Diameter = internalDiameter;
+                                }
+                                if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
+                                {
+                                    translation.MinorLoss = minorLoss;
+                                }
+                                if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
+                                {
+                                    translation.Roughness = roughness;
+                                }
+                                if (translation.Length <= 0)
+                                {
+                                    translation.Length = translation.StartPosition.Distance(translation.EndPosition);
+                                }
+                                if (translation.Diameter < 0.1)
+                                {
+                                    translation.Diameter = 0.1;
+                                }
+                                if (translation.Roughness < 0.1)
+                                {
+                                    translation.Roughness = 0.1;
+                                }
+                                model.Translations.Add(translation);
                             }
                             break;
                         case RevitJsonCatalog.Pump:
@@ -776,23 +883,24 @@
                                 pump.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 pump.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 pump.Description = jobject[RevitJsonProp.Description].ToString();
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var startLinker = linkList.GetStartLinker();
-                                var endLinker = linkList.GetEndLinker();
-                                pump.StartCode = startLinker.ConnectId;
-                                pump.EndCode = endLinker.ConnectId;
-                                pump.StartPosition = new Model.RevitPosition()
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                pump.ConnectList = connectList?.Select(x => new Model.RevitConnect()
                                 {
-                                    X = startLinker.Point.X,
-                                    Y = startLinker.Point.Y,
-                                    Z = startLinker.Point.Z
-                                };
-                                pump.EndPosition = new Model.RevitPosition()
-                                {
-                                    X = endLinker.Point.X,
-                                    Y = endLinker.Point.Y,
-                                    Z = endLinker.Point.Z
-                                };
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+                                var startConnect = pump.ConnectList.GetStartConnect();
+                                var endConnect = pump.ConnectList.GetEndConnect();
+                                pump.StartCode = startConnect.Id;
+                                pump.EndCode = endConnect.Id;
+                                pump.StartPosition = startConnect.Position;
+                                pump.EndPosition = endConnect.Position;
                                 pump.LinkStatus = jobject[RevitJsonProp.LinkStatusPump].ToString();
                                 if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
                                 {
@@ -842,23 +950,24 @@
                                 valve.ModelType = jobject[RevitJsonProp.ModelType].ToString();
                                 valve.Flags = Yw.Untity.FlagsHelper.ToList(jobject[RevitJsonProp.Flags].ToString());
                                 valve.Description = jobject[RevitJsonProp.Description].ToString();
-                                var linkList = JsonHelper.Json2Object<List<RevitJsonLinkerModel>>(jobject[RevitJsonProp.Links].ToString());
-                                var startLinker = linkList.GetStartLinker();
-                                var endLinker = linkList.GetEndLinker();
-                                valve.StartCode = startLinker.ConnectId;
-                                valve.EndCode = endLinker.ConnectId;
-                                valve.StartPosition = new Model.RevitPosition()
+                                var connectList = JsonHelper.Json2Object<List<RevitJsonConnectModel>>(jobject[RevitJsonProp.Connects].ToString());
+                                valve.ConnectList = connectList?.Select(x => new Model.RevitConnect()
                                 {
-                                    X = startLinker.Point.X,
-                                    Y = startLinker.Point.Y,
-                                    Z = startLinker.Point.Z
-                                };
-                                valve.EndPosition = new Model.RevitPosition()
-                                {
-                                    X = endLinker.Point.X,
-                                    Y = endLinker.Point.Y,
-                                    Z = endLinker.Point.Z
-                                };
+                                    Id = x.ConnectId,
+                                    Direction = x.Dirction,
+                                    Position = new Model.RevitPosition()
+                                    {
+                                        X = x.Point.X,
+                                        Y = x.Point.Y,
+                                        Z = x.Point.Z
+                                    }
+                                }).ToList();
+                                var startConnect = valve.ConnectList.GetStartConnect();
+                                var endConnect = valve.ConnectList.GetEndConnect();
+                                valve.StartCode = startConnect.Id;
+                                valve.EndCode = endConnect.Id;
+                                valve.StartPosition = startConnect.Position;
+                                valve.EndPosition = endConnect.Position;
                                 valve.LinkStatus = jobject[RevitJsonProp.LinkStatusValve].ToString();
                                 if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
                                 {

--
Gitblit v1.9.3