From 6c88a90d2330a27c0052a22538f6ebd6200faae7 Mon Sep 17 00:00:00 2001
From: duheng <2784771470@qq.com>
Date: 星期三, 21 八月 2024 18:02:15 +0800
Subject: [PATCH] 完善主界面

---
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.cs                               |   11 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.Designer.cs |   37 +
 WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/00-ViewModel/TreelistViewModel.cs                         |    4 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrViewModel.cs                                       |   28 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.cs                                                     |   63 ++
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.resx        |  120 +++++
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.Designer.cs                        |   32 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.Designer.cs                      |   44 +
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.resx                                          |   24 +
 WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.Designer.cs                                                             |   10 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.resx        |   65 --
 WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/PumpProductSeriesTreeListCtrl.cs                          |    2 
 WinFrmUI/HStation.WinFrmUI.PhartRelation.Core/01-pump-main/XhsPumpMainPhartListCtrl.cs                                |    4 
 WinFrmUI/HStation.WinFrmUI.Core/Resources/未导入提示.png                                                                   |    0 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/js/xhs_base64.js                                                        |    2 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeViewModel.cs                                 |   24 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj                                                 |    3 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectHelper.cs                            |  210 ++++----
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.Designer.cs |   20 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.cs          |   87 +++
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.Designer.cs                         |   11 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj.user                                            |    3 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.cs                                  |   39 +
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.cs                                 |   18 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.cs                                            |   81 +++
 WinFrmUI/Hstation.WinFrmUI.Core/Lib/ImageLib.cs                                                                       |   53 +
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.cs          |   23 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.resx                                |   20 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.resx                             |   88 +++
 WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.resx                                                                    |    3 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/img/xhs_project.png                                                     |    0 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.Designer.cs                                            |  204 ++++----
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/03-MapLocation/SetXhsProjectMapLocationWizardPage.cs         |    4 
 WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.Designer.cs                                   |   69 ++
 34 files changed, 981 insertions(+), 425 deletions(-)

diff --git a/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/00-ViewModel/TreelistViewModel.cs b/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/00-ViewModel/TreelistViewModel.cs
index 9de0c72..6d043ca 100644
--- a/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/00-ViewModel/TreelistViewModel.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/00-ViewModel/TreelistViewModel.cs
@@ -16,7 +16,7 @@
             this.SortCode = rhs.SortCode;
             this.Description = rhs.Description;
             this.Model = rhs;
-            this.ImageIndex = ImageLib.Series16;
+            this.ImageIndex = ImageLib.Series;
         }
 
         public CurrentTreeViewModel(Vmo.PumpGroup rhs) : base()
@@ -29,7 +29,7 @@
             this.Description = rhs.Description;
             this.Model = rhs;
             this.IsGroup = true;
-            this.ImageIndex = ImageLib.Group16;
+            this.ImageIndex = ImageLib.Group;
         }
 
         public void Reset(Vmo.PumpSeries rhs)
diff --git a/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/PumpProductSeriesTreeListCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/PumpProductSeriesTreeListCtrl.cs
index 252d600..1eeb7d6 100644
--- a/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/PumpProductSeriesTreeListCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Assets.Core/00-PumpProductManage/PumpProductSeriesTreeListCtrl.cs
@@ -12,7 +12,7 @@
         {
             InitializeComponent();
             this.treeList1.InitialDefaultSettings();
-            this.treeList1.SelectImageList = ImageLib.Lib16;
+            this.treeList1.SelectImageList = ImageLib.Lib;
         }
 
         /// <summary>
diff --git "a/WinFrmUI/HStation.WinFrmUI.Core/Resources/\346\234\252\345\257\274\345\205\245\346\217\220\347\244\272.png" "b/WinFrmUI/HStation.WinFrmUI.Core/Resources/\346\234\252\345\257\274\345\205\245\346\217\220\347\244\272.png"
new file mode 100644
index 0000000..b085ab9
--- /dev/null
+++ "b/WinFrmUI/HStation.WinFrmUI.Core/Resources/\346\234\252\345\257\274\345\205\245\346\217\220\347\244\272.png"
Binary files differ
diff --git a/WinFrmUI/HStation.WinFrmUI.PhartRelation.Core/01-pump-main/XhsPumpMainPhartListCtrl.cs b/WinFrmUI/HStation.WinFrmUI.PhartRelation.Core/01-pump-main/XhsPumpMainPhartListCtrl.cs
index 99155d6..ae49fc3 100644
--- a/WinFrmUI/HStation.WinFrmUI.PhartRelation.Core/01-pump-main/XhsPumpMainPhartListCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.PhartRelation.Core/01-pump-main/XhsPumpMainPhartListCtrl.cs
@@ -9,7 +9,7 @@
         {
             InitializeComponent();
             this.treeList1.InitialDefaultSettings(); 
-            this.treeList1.SelectImageList = ImageLib.Lib16;
+            this.treeList1.SelectImageList = ImageLib.Lib;
             this.layoutControl1.SetupLayoutControl();
         }
 
@@ -23,7 +23,7 @@
                 this.Name = model.OtherName;
                 this.Importance = model.Importance;
                 this.SortCode = model.SortCode;
-                this.ImageIndex= ImageLib.Question16;
+                this.ImageIndex= ImageLib.Question;
                 this.Model = model;
             } 
             public long ID { get; set; }
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.Designer.cs
index 0c73589..eb36ec8 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.Designer.cs
@@ -30,8 +30,8 @@
         {
             components = new Container();
             ComponentResourceManager resources = new ComponentResourceManager(typeof(HomeXhsProjectTreeListCtrl));
-            DevExpress.Utils.SuperToolTip superToolTip1 = new DevExpress.Utils.SuperToolTip();
-            DevExpress.Utils.ToolTipItem toolTipItem1 = new DevExpress.Utils.ToolTipItem();
+            DevExpress.Utils.SuperToolTip superToolTip2 = new DevExpress.Utils.SuperToolTip();
+            DevExpress.Utils.ToolTipItem toolTipItem2 = new DevExpress.Utils.ToolTipItem();
             layoutControl1 = new DevExpress.XtraLayout.LayoutControl();
             btnImportProject = new DevExpress.XtraEditors.SimpleButton();
             treeList1 = new DevExpress.XtraTreeList.TreeList();
@@ -114,6 +114,7 @@
             // 
             colName.Caption = "鍚嶇О";
             colName.FieldName = "Name";
+            colName.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("colName.ImageOptions.SvgImage");
             colName.Name = "colName";
             colName.Visible = true;
             colName.VisibleIndex = 0;
@@ -181,9 +182,9 @@
             barBtnRefresh.Id = 5;
             barBtnRefresh.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnRefresh.ImageOptions.SvgImage");
             barBtnRefresh.Name = "barBtnRefresh";
-            toolTipItem1.Text = "鍒锋柊";
-            superToolTip1.Items.Add(toolTipItem1);
-            barBtnRefresh.SuperTip = superToolTip1;
+            toolTipItem2.Text = "鍒锋柊";
+            superToolTip2.Items.Add(toolTipItem2);
+            barBtnRefresh.SuperTip = superToolTip2;
             barBtnRefresh.ItemClick += barBtnRefresh_ItemClick;
             // 
             // barDockControlTop
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.cs
index ad71cb0..1f433dc 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.cs
@@ -25,24 +25,54 @@
         /// 椤圭洰瀵煎叆瀹屾垚浜嬩欢
         /// </summary>
         public event Action<ImportXhsProjectViewModel> ImportProjectCompletedEvent;
+
         private List<HomeXhsProjectTreeViewModel> _allBindingList = null;//褰撳墠缁戝畾鍒楄〃
 
         /// <summary>
         /// 缁戝畾鏁版嵁
         /// </summary>
-        public void SetBindingData(List<XhsProjectStdDto> allProjectList)
+        public async void SetBindingData(List<XhsProjectStdDto> allProjectList)
         {
             _allBindingList = new List<HomeXhsProjectTreeViewModel>();
             foreach (var item in allProjectList)
             {
-                var vm = new HomeXhsProjectTreeViewModel(item);
-                _allBindingList.Add(vm);
+                if (await IsHaveBimFace(item.ID))
+                {
+                    var vm = new HomeXhsProjectTreeViewModel(item, true);
+                    _allBindingList.Add(vm);
+                }
+                else
+                {
+                    var vm = new HomeXhsProjectTreeViewModel(item, false);
+                    _allBindingList.Add(vm);
+                }
             }
             this.treeList1.DataSource = _allBindingList;
             this.treeList1.ForceInitialize();
             this.treeList1.ExpandAll();
         }
 
+        //鏌ユ壘椤圭洰鏄惁瀛樺湪妯″瀷
+        private async Task<bool> IsHaveBimFace(long ProjectID)
+        {
+            var projectSite = await new BLL.XhsProjectSiteStd().GetDefaultByProjectID(ProjectID);
+            if (projectSite == null)
+            {
+                return false;
+            }
+            var relation = await new Yw.BLL.BimfaceFileRelationStd()
+               .GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, projectSite.ID, Yw.Bimface.Purpose.Simulation);
+            if (relation == null)
+            {
+                return false;
+            }
+            var bimfaceFile = await new Yw.BLL.BimfaceFileStd().GetByID(relation.BimfaceFileID);
+            if (bimfaceFile == null)
+            {
+                return false;
+            }
+            return true;
+        }
 
         /// <summary>
         /// 璁剧疆榛樿
@@ -133,6 +163,5 @@
         {
             this.RefreshDataEvent?.Invoke();
         }
-
     }
-}
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.resx b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.resx
index 17e74c3..40e7e78 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.resx
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeListCtrl.resx
@@ -145,6 +145,26 @@
         IDwvZz4NCjwvc3ZnPgs=
 </value>
   </data>
+  <data name="colName.ImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAOMCAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTmV3VGFibGVTdHlsZSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5l
+        dyAwIDAgMzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkJsdWV7ZmlsbDojMTE3N0Q3
+        O30KCS5CbGFja3tmaWxsOiM3MjcyNzI7fQoJLlllbGxvd3tmaWxsOiNGRkIxMTU7fQoJLnN0MHtvcGFj
+        aXR5OjAuNTt9Cjwvc3R5bGU+DQogIDxnIGNsYXNzPSJzdDAiPg0KICAgIDxwYXRoIGQ9Ik0wLDIwaDh2
+        NkgwVjIweiBNMTAsMjZoOHYtNmgtOFYyNnogTTIwLDEydjZoOHYtNkgyMHogTTIwLDI2aDh2LTZoLThW
+        MjZ6IiBjbGFzcz0iQmxhY2siIC8+DQogIDwvZz4NCiAgPHBhdGggZD0iTTAsNGg4djZIMFY0eiBNMCwx
+        OGg4di02SDBWMTh6IE0xMCwxMGg4VjRoLThWMTB6IE0xMCwxOGg4di02aC04VjE4eiIgY2xhc3M9IkJs
+        dWUiIC8+DQogIDxwb2x5Z29uIHBvaW50cz0iMjUsMiAyNywwIDI3LDMgMzAsMyAyOCw1IDMwLDcgMjcs
+        NyAyNywxMCAyNSw4IDIzLDEwIDIzLDcgMjAsNyAyMiw1IDIwLDMgMjMsMyAyMywwICIgY2xhc3M9Illl
+        bGxvdyIgLz4NCjwvc3ZnPgs=
+</value>
+  </data>
   <metadata name="barManager1.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
     <value>17, 17</value>
   </metadata>
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeViewModel.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeViewModel.cs
index e78bfef..e066098 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeViewModel.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/01-project/HomeXhsProjectTreeViewModel.cs
@@ -1,19 +1,20 @@
 锘縩amespace HStation.WinFrmUI
 {
     /// <summary>
-    /// 
+    ///
     /// </summary>
     public class HomeXhsProjectTreeViewModel
     {
         /// <summary>
-        /// 
+        ///
         /// </summary>
-        public HomeXhsProjectTreeViewModel() { }
+        public HomeXhsProjectTreeViewModel()
+        { }
 
         /// <summary>
-        /// 
+        ///
         /// </summary>
-        public HomeXhsProjectTreeViewModel(XhsProjectStdDto rhs)
+        public HomeXhsProjectTreeViewModel(XhsProjectStdDto rhs, bool IsHave)
         {
             this.ID = rhs.ID;
             this.ParentID = rhs.ParentID;
@@ -21,7 +22,11 @@
             this.SortCode = rhs.SortCode;
             this.Description = rhs.Description;
             this.Project = rhs;
-        }
+            if (IsHave)
+            {
+                this.ImageIndex = ImageLib.NotImported;
+            }
+         }
 
         /// <summary>
         /// ID
@@ -52,5 +57,10 @@
         /// 椤圭洰
         /// </summary>
         public XhsProjectStdDto Project { get; set; }
+
+        /// <summary>
+        /// 鍥炬爣绱㈠紩
+        /// </summary>
+        public int? ImageIndex { get; set; }
     }
-}
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.Designer.cs
index 5f0692f..5cf6cc4 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.Designer.cs
@@ -47,11 +47,11 @@
             barBtnExpandAll = new DevExpress.XtraBars.BarButtonItem();
             barBtnCollpseAll = new DevExpress.XtraBars.BarButtonItem();
             barBtnHelp = new DevExpress.XtraBars.BarButtonItem();
+            barBtnDirect = new DevExpress.XtraBars.BarButtonItem();
             barDockControlTop = new DevExpress.XtraBars.BarDockControl();
             barDockControlBottom = new DevExpress.XtraBars.BarDockControl();
             barDockControlLeft = new DevExpress.XtraBars.BarDockControl();
             barDockControlRight = new DevExpress.XtraBars.BarDockControl();
-            barBtnDirect = new DevExpress.XtraBars.BarButtonItem();
             ((ISupportInitialize)layoutControl1).BeginInit();
             layoutControl1.SuspendLayout();
             ((ISupportInitialize)propertyGridControl1).BeginInit();
@@ -174,7 +174,7 @@
             bar1.DockRow = 0;
             bar1.DockStyle = DevExpress.XtraBars.BarDockStyle.Top;
             bar1.FloatLocation = new Point(1899, 679);
-            bar1.LinksPersistInfo.AddRange(new DevExpress.XtraBars.LinkPersistInfo[] { new DevExpress.XtraBars.LinkPersistInfo(barBtnExpandAll), new DevExpress.XtraBars.LinkPersistInfo(barBtnCollpseAll), new DevExpress.XtraBars.LinkPersistInfo(barBtnHelp), new DevExpress.XtraBars.LinkPersistInfo(barBtnDirect) });
+            bar1.LinksPersistInfo.AddRange(new DevExpress.XtraBars.LinkPersistInfo[] { new DevExpress.XtraBars.LinkPersistInfo(barBtnExpandAll), new DevExpress.XtraBars.LinkPersistInfo(barBtnCollpseAll), new DevExpress.XtraBars.LinkPersistInfo(barBtnHelp), new DevExpress.XtraBars.LinkPersistInfo(barBtnDirect, true) });
             bar1.OptionsBar.AllowQuickCustomization = false;
             bar1.OptionsBar.DrawBorder = false;
             bar1.OptionsBar.RotateWhenVertical = false;
@@ -188,6 +188,7 @@
             barBtnExpandAll.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnExpandAll.ImageOptions.SvgImage");
             barBtnExpandAll.ImageOptions.SvgImageSize = new Size(20, 20);
             barBtnExpandAll.Name = "barBtnExpandAll";
+            barBtnExpandAll.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
             barBtnExpandAll.ItemClick += barBtnExpandAll_ItemClick;
             // 
             // barBtnCollpseAll
@@ -197,6 +198,7 @@
             barBtnCollpseAll.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnCollpseAll.ImageOptions.SvgImage");
             barBtnCollpseAll.ImageOptions.SvgImageSize = new Size(20, 20);
             barBtnCollpseAll.Name = "barBtnCollpseAll";
+            barBtnCollpseAll.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
             barBtnCollpseAll.ItemClick += barBtnCollpseAll_ItemClick;
             // 
             // barBtnHelp
@@ -215,6 +217,19 @@
             superToolTip1.Items.Add(toolTipItem1);
             barBtnHelp.SuperTip = superToolTip1;
             barBtnHelp.ItemClick += barBtnHelp_ItemClick;
+            // 
+            // barBtnDirect
+            // 
+            barBtnDirect.Caption = "璺宠浆";
+            barBtnDirect.Id = 15;
+            barBtnDirect.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnDirect.ImageOptions.SvgImage");
+            barBtnDirect.ImageOptions.SvgImageSize = new Size(24, 20);
+            barBtnDirect.Name = "barBtnDirect";
+            toolTipItem2.AllowHtmlText = DevExpress.Utils.DefaultBoolean.True;
+            toolTipItem2.Text = "璺宠浆";
+            superToolTip2.Items.Add(toolTipItem2);
+            barBtnDirect.SuperTip = superToolTip2;
+            barBtnDirect.ItemClick += barBtnDirect_ItemClick;
             // 
             // barDockControlTop
             // 
@@ -247,19 +262,6 @@
             barDockControlRight.Location = new Point(260, 28);
             barDockControlRight.Manager = barManager1;
             barDockControlRight.Size = new Size(0, 602);
-            // 
-            // barBtnDirect
-            // 
-            barBtnDirect.Caption = "璺宠浆";
-            barBtnDirect.Id = 15;
-            barBtnDirect.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnDirect.ImageOptions.SvgImage");
-            barBtnDirect.ImageOptions.SvgImageSize = new Size(24, 20);
-            barBtnDirect.Name = "barBtnDirect";
-            toolTipItem2.AllowHtmlText = DevExpress.Utils.DefaultBoolean.True;
-            toolTipItem2.Text = "璺宠浆";
-            superToolTip2.Items.Add(toolTipItem2);
-            barBtnDirect.SuperTip = superToolTip2;
-            barBtnDirect.ItemClick += barBtnDirect_ItemClick;
             // 
             // HomeXhsProjectPropertyCtrl
             // 
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.cs
index 4c4df2d..53def88 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/03-property/HomeXhsProjectPropertyCtrl.cs
@@ -6,7 +6,6 @@
 
 namespace HStation.WinFrmUI
 {
-
     public partial class HomeXhsProjectPropertyCtrl : XtraUserControl
     {
         public HomeXhsProjectPropertyCtrl()
@@ -162,7 +161,7 @@
                 }
             }
 
-            #endregion
+            #endregion 灞炴�ф樉绀哄悕绉板拰鎻忚堪
 
             #region bool
 
@@ -177,7 +176,7 @@
                 e.RepositoryItem = ckEdit;
             }
 
-            #endregion
+            #endregion bool
 
             #region 瀵屾枃鏈�
 
@@ -192,7 +191,7 @@
                 e.RepositoryItem = memoEdit;
             }
 
-            #endregion
+            #endregion 瀵屾枃鏈�
 
             #region 鍥剧墖
 
@@ -205,18 +204,16 @@
                 e.Row.Expanded = true;
             }
 
-            #endregion
-
+            #endregion 鍥剧墖
         }
 
         //灞炴�у�兼鍦ㄦ敼鍙�
-        void propertyGridControl1_CellValueChanging(object sender, DevExpress.XtraVerticalGrid.Events.CellValueChangedEventArgs e)
+        private void propertyGridControl1_CellValueChanging(object sender, DevExpress.XtraVerticalGrid.Events.CellValueChangedEventArgs e)
         {
-
         }
 
         //灞炴�у�兼敼鍙橈紝鏇存柊鍦板浘鍜孞sonModel瀵硅薄
-        void propertyGridControl1_CellValueChanged(object sender, DevExpress.XtraVerticalGrid.Events.CellValueChangedEventArgs e)
+        private void propertyGridControl1_CellValueChanged(object sender, DevExpress.XtraVerticalGrid.Events.CellValueChangedEventArgs e)
         {
             var fieldName = e.Row.Properties.FieldName.Split(new char[] { '.' }).Last();
             var descriptor = this.propertyGridControl1.GetPropertyDescriptor(e.Row);
@@ -249,7 +246,6 @@
                 return;
             }
             JumpDirectEvent?.Invoke(this.SelectedObject.Project);
-
         }
     }
-}
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.Designer.cs
index 0889d5b..bc5bf09 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.Designer.cs
@@ -37,9 +37,13 @@
             gridControl1 = new DevExpress.XtraGrid.GridControl();
             layoutView1 = new DevExpress.XtraGrid.Views.Layout.LayoutView();
             colName = new DevExpress.XtraGrid.Columns.LayoutViewColumn();
+            layoutViewField_colName = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
             colCount = new DevExpress.XtraGrid.Columns.LayoutViewColumn();
+            layoutViewField_colCount = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
             colPicture = new DevExpress.XtraGrid.Columns.LayoutViewColumn();
             repPicEdit = new DevExpress.XtraEditors.Repository.RepositoryItemPictureEdit();
+            layoutViewField_colPicture = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
+            layoutViewCard1 = new DevExpress.XtraGrid.Views.Layout.LayoutViewCard();
             gridView1 = new DevExpress.XtraGrid.Views.Grid.GridView();
             sidePanelBottom = new DevExpress.XtraEditors.SidePanel();
             dockPanelFill = new DevExpress.XtraBars.Docking.DockPanel();
@@ -49,15 +53,15 @@
             dockPanelLeft = new DevExpress.XtraBars.Docking.DockPanel();
             dockPanel1_Container = new DevExpress.XtraBars.Docking.ControlContainer();
             dockManager1 = new DevExpress.XtraBars.Docking.DockManager(components);
-            layoutViewCard1 = new DevExpress.XtraGrid.Views.Layout.LayoutViewCard();
-            layoutViewField_colCount = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
-            layoutViewField_colPicture = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
-            layoutViewField_colName = new DevExpress.XtraGrid.Views.Layout.LayoutViewField();
             ((ISupportInitialize)svgImg32).BeginInit();
             sidePanel1.SuspendLayout();
             ((ISupportInitialize)gridControl1).BeginInit();
             ((ISupportInitialize)layoutView1).BeginInit();
+            ((ISupportInitialize)layoutViewField_colName).BeginInit();
+            ((ISupportInitialize)layoutViewField_colCount).BeginInit();
             ((ISupportInitialize)repPicEdit).BeginInit();
+            ((ISupportInitialize)layoutViewField_colPicture).BeginInit();
+            ((ISupportInitialize)layoutViewCard1).BeginInit();
             ((ISupportInitialize)gridView1).BeginInit();
             sidePanelBottom.SuspendLayout();
             dockPanelFill.SuspendLayout();
@@ -67,30 +71,26 @@
             dockPanelLeft.SuspendLayout();
             dockPanel1_Container.SuspendLayout();
             ((ISupportInitialize)dockManager1).BeginInit();
-            ((ISupportInitialize)layoutViewCard1).BeginInit();
-            ((ISupportInitialize)layoutViewField_colCount).BeginInit();
-            ((ISupportInitialize)layoutViewField_colPicture).BeginInit();
-            ((ISupportInitialize)layoutViewField_colName).BeginInit();
             SuspendLayout();
             // 
             // mapViewProjectListContainer1
             // 
             mapViewProjectListContainer1.Dock = DockStyle.Fill;
             mapViewProjectListContainer1.Location = new Point(0, 0);
-            mapViewProjectListContainer1.Margin = new Padding(4, 3, 4, 3);
+            mapViewProjectListContainer1.Margin = new Padding(3, 2, 3, 2);
             mapViewProjectListContainer1.Name = "mapViewProjectListContainer1";
-            mapViewProjectListContainer1.Padding = new Padding(1, 2, 1, 2);
-            mapViewProjectListContainer1.Size = new Size(926, 882);
+            mapViewProjectListContainer1.Padding = new Padding(1);
+            mapViewProjectListContainer1.Size = new Size(665, 560);
             mapViewProjectListContainer1.TabIndex = 5;
             // 
             // homeXhsProjectPropertyCtrl1
             // 
             homeXhsProjectPropertyCtrl1.Dock = DockStyle.Fill;
             homeXhsProjectPropertyCtrl1.Location = new Point(0, 0);
-            homeXhsProjectPropertyCtrl1.Margin = new Padding(6, 8, 6, 8);
+            homeXhsProjectPropertyCtrl1.Margin = new Padding(4, 5, 4, 5);
             homeXhsProjectPropertyCtrl1.Name = "homeXhsProjectPropertyCtrl1";
             homeXhsProjectPropertyCtrl1.SelectedObject = null;
-            homeXhsProjectPropertyCtrl1.Size = new Size(298, 882);
+            homeXhsProjectPropertyCtrl1.Size = new Size(206, 560);
             homeXhsProjectPropertyCtrl1.TabIndex = 0;
             homeXhsProjectPropertyCtrl1.JumpDirectEvent += homeXhsProjectPropertyCtrl1_JumpDirectEvent;
             // 
@@ -98,9 +98,9 @@
             // 
             homeXhsProjectTreeListCtrl1.Dock = DockStyle.Fill;
             homeXhsProjectTreeListCtrl1.Location = new Point(0, 0);
-            homeXhsProjectTreeListCtrl1.Margin = new Padding(6, 8, 6, 8);
+            homeXhsProjectTreeListCtrl1.Margin = new Padding(4, 5, 4, 5);
             homeXhsProjectTreeListCtrl1.Name = "homeXhsProjectTreeListCtrl1";
-            homeXhsProjectTreeListCtrl1.Size = new Size(293, 882);
+            homeXhsProjectTreeListCtrl1.Size = new Size(190, 560);
             homeXhsProjectTreeListCtrl1.TabIndex = 0;
             homeXhsProjectTreeListCtrl1.SelectProjectEvent += homeXhsProjectTreeListCtrl1_SelectProjectEvent;
             homeXhsProjectTreeListCtrl1.RefreshDataEvent += homeXhsProjectTreeListCtrl1_RefreshDataEvent;
@@ -116,20 +116,21 @@
             sidePanel1.Controls.Add(gridControl1);
             sidePanel1.Dock = DockStyle.Top;
             sidePanel1.Location = new Point(0, 0);
-            sidePanel1.Margin = new Padding(4, 5, 4, 5);
             sidePanel1.Name = "sidePanel1";
-            sidePanel1.Size = new Size(1519, 148);
+            sidePanel1.Size = new Size(1063, 94);
             sidePanel1.TabIndex = 1;
             sidePanel1.Text = "sidePanel1";
             // 
             // gridControl1
             // 
             gridControl1.Dock = DockStyle.Fill;
+            gridControl1.EmbeddedNavigator.Margin = new Padding(2);
             gridControl1.Location = new Point(0, 0);
             gridControl1.MainView = layoutView1;
+            gridControl1.Margin = new Padding(2);
             gridControl1.Name = "gridControl1";
             gridControl1.RepositoryItems.AddRange(new DevExpress.XtraEditors.Repository.RepositoryItem[] { repPicEdit });
-            gridControl1.Size = new Size(1519, 147);
+            gridControl1.Size = new Size(1063, 93);
             gridControl1.TabIndex = 0;
             gridControl1.ViewCollection.AddRange(new DevExpress.XtraGrid.Views.Base.BaseView[] { layoutView1, gridView1 });
             // 
@@ -143,9 +144,10 @@
             layoutView1.Appearance.FieldValue.Options.UseBackColor = true;
             layoutView1.BorderStyle = DevExpress.XtraEditors.Controls.BorderStyles.NoBorder;
             layoutView1.CardHorzInterval = 4;
-            layoutView1.CardMinSize = new Size(300, 109);
+            layoutView1.CardMinSize = new Size(210, 69);
             layoutView1.CardVertInterval = 0;
             layoutView1.Columns.AddRange(new DevExpress.XtraGrid.Columns.LayoutViewColumn[] { colName, colCount, colPicture });
+            layoutView1.DetailHeight = 223;
             layoutView1.GridControl = gridControl1;
             layoutView1.Name = "layoutView1";
             layoutView1.OptionsBehavior.Editable = false;
@@ -163,6 +165,7 @@
             layoutView1.OptionsView.ShowHeaderPanel = false;
             layoutView1.OptionsView.ViewMode = DevExpress.XtraGrid.Views.Layout.LayoutViewMode.Row;
             layoutView1.TemplateCard = layoutViewCard1;
+            layoutView1.FieldValueClick += layoutView1_FieldValueClick;
             // 
             // colName
             // 
@@ -175,9 +178,21 @@
             colName.Caption = "鍚嶇О";
             colName.FieldName = "Name";
             colName.LayoutViewField = layoutViewField_colName;
-            colName.MinWidth = 30;
+            colName.MinWidth = 21;
             colName.Name = "colName";
-            colName.Width = 112;
+            colName.Width = 78;
+            // 
+            // layoutViewField_colName
+            // 
+            layoutViewField_colName.ContentHorzAlignment = DevExpress.Utils.HorzAlignment.Center;
+            layoutViewField_colName.ContentVertAlignment = DevExpress.Utils.VertAlignment.Center;
+            layoutViewField_colName.EditorPreferredWidth = 106;
+            layoutViewField_colName.Location = new Point(133, 0);
+            layoutViewField_colName.Name = "layoutViewField_colName";
+            layoutViewField_colName.Padding = new DevExpress.XtraLayout.Utils.Padding(3, 3, 3, 3);
+            layoutViewField_colName.Size = new Size(159, 36);
+            layoutViewField_colName.TextSize = new Size(0, 0);
+            layoutViewField_colName.TextVisible = false;
             // 
             // colCount
             // 
@@ -189,9 +204,21 @@
             colCount.Caption = "鏁伴噺";
             colCount.FieldName = "Count";
             colCount.LayoutViewField = layoutViewField_colCount;
-            colCount.MinWidth = 30;
+            colCount.MinWidth = 21;
             colCount.Name = "colCount";
-            colCount.Width = 112;
+            colCount.Width = 78;
+            // 
+            // layoutViewField_colCount
+            // 
+            layoutViewField_colCount.ContentHorzAlignment = DevExpress.Utils.HorzAlignment.Center;
+            layoutViewField_colCount.ContentVertAlignment = DevExpress.Utils.VertAlignment.Center;
+            layoutViewField_colCount.EditorPreferredWidth = 106;
+            layoutViewField_colCount.Location = new Point(133, 36);
+            layoutViewField_colCount.Name = "layoutViewField_colCount";
+            layoutViewField_colCount.Padding = new DevExpress.XtraLayout.Utils.Padding(3, 3, 3, 3);
+            layoutViewField_colCount.Size = new Size(159, 65);
+            layoutViewField_colCount.TextSize = new Size(0, 0);
+            layoutViewField_colCount.TextVisible = false;
             // 
             // colPicture
             // 
@@ -199,18 +226,43 @@
             colPicture.ColumnEdit = repPicEdit;
             colPicture.FieldName = "Image";
             colPicture.LayoutViewField = layoutViewField_colPicture;
-            colPicture.MinWidth = 30;
+            colPicture.MinWidth = 21;
             colPicture.Name = "colPicture";
-            colPicture.Width = 112;
+            colPicture.Width = 78;
             // 
             // repPicEdit
             // 
             repPicEdit.Name = "repPicEdit";
             // 
+            // layoutViewField_colPicture
+            // 
+            layoutViewField_colPicture.EditorPreferredWidth = 87;
+            layoutViewField_colPicture.Location = new Point(0, 0);
+            layoutViewField_colPicture.Name = "layoutViewField_colPicture";
+            layoutViewField_colPicture.Padding = new DevExpress.XtraLayout.Utils.Padding(3, 3, 3, 3);
+            layoutViewField_colPicture.Size = new Size(133, 101);
+            layoutViewField_colPicture.StartNewLine = true;
+            layoutViewField_colPicture.TextSize = new Size(0, 0);
+            layoutViewField_colPicture.TextVisible = false;
+            // 
+            // layoutViewCard1
+            // 
+            layoutViewCard1.CustomizationFormText = "TemplateCard";
+            layoutViewCard1.GroupBordersVisible = false;
+            layoutViewCard1.GroupStyle = DevExpress.Utils.GroupStyle.Light;
+            layoutViewCard1.HeaderButtonsLocation = DevExpress.Utils.GroupElementLocation.AfterText;
+            layoutViewCard1.Items.AddRange(new DevExpress.XtraLayout.BaseLayoutItem[] { layoutViewField_colCount, layoutViewField_colPicture, layoutViewField_colName });
+            layoutViewCard1.Name = "layoutViewCard1";
+            layoutViewCard1.OptionsItemText.TextToControlDistance = 3;
+            layoutViewCard1.Padding = new DevExpress.XtraLayout.Utils.Padding(3, 3, 3, 3);
+            layoutViewCard1.Text = "TemplateCard";
+            // 
             // gridView1
             // 
+            gridView1.DetailHeight = 223;
             gridView1.GridControl = gridControl1;
             gridView1.Name = "gridView1";
+            gridView1.OptionsEditForm.PopupEditFormWidth = 560;
             // 
             // sidePanelBottom
             // 
@@ -218,10 +270,9 @@
             sidePanelBottom.Controls.Add(dockPanelRight);
             sidePanelBottom.Controls.Add(dockPanelLeft);
             sidePanelBottom.Dock = DockStyle.Fill;
-            sidePanelBottom.Location = new Point(0, 148);
-            sidePanelBottom.Margin = new Padding(4, 5, 4, 5);
+            sidePanelBottom.Location = new Point(0, 94);
             sidePanelBottom.Name = "sidePanelBottom";
-            sidePanelBottom.Size = new Size(1519, 916);
+            sidePanelBottom.Size = new Size(1063, 583);
             sidePanelBottom.TabIndex = 7;
             sidePanelBottom.Text = "sidePanel3";
             // 
@@ -234,19 +285,21 @@
             dockPanelFill.Controls.Add(controlContainer2);
             dockPanelFill.Dock = DevExpress.XtraBars.Docking.DockingStyle.Fill;
             dockPanelFill.ID = new Guid("136389ea-6552-4166-8c2a-b2ffe8b01953");
-            dockPanelFill.Location = new Point(294, 0);
+            dockPanelFill.Location = new Point(191, 0);
+            dockPanelFill.Margin = new Padding(2);
             dockPanelFill.Name = "dockPanelFill";
             dockPanelFill.Options.ShowCloseButton = false;
-            dockPanelFill.OriginalSize = new Size(1525, 200);
-            dockPanelFill.Size = new Size(926, 916);
+            dockPanelFill.OriginalSize = new Size(287, 200);
+            dockPanelFill.Size = new Size(665, 583);
             dockPanelFill.Text = "鍦板浘";
             // 
             // controlContainer2
             // 
             controlContainer2.Controls.Add(mapViewProjectListContainer1);
-            controlContainer2.Location = new Point(0, 34);
+            controlContainer2.Location = new Point(0, 23);
+            controlContainer2.Margin = new Padding(2);
             controlContainer2.Name = "controlContainer2";
-            controlContainer2.Size = new Size(926, 882);
+            controlContainer2.Size = new Size(665, 560);
             controlContainer2.TabIndex = 0;
             // 
             // dockPanelRight
@@ -254,19 +307,21 @@
             dockPanelRight.Controls.Add(controlContainer1);
             dockPanelRight.Dock = DevExpress.XtraBars.Docking.DockingStyle.Right;
             dockPanelRight.ID = new Guid("18c9fca9-8ae9-473c-9cd2-0467d818af3f");
-            dockPanelRight.Location = new Point(1220, 0);
+            dockPanelRight.Location = new Point(856, 0);
+            dockPanelRight.Margin = new Padding(2);
             dockPanelRight.Name = "dockPanelRight";
             dockPanelRight.Options.ShowCloseButton = false;
-            dockPanelRight.OriginalSize = new Size(299, 200);
-            dockPanelRight.Size = new Size(299, 916);
-            dockPanelRight.Text = "灞炴�ч潰鏉�";
+            dockPanelRight.OriginalSize = new Size(207, 200);
+            dockPanelRight.Size = new Size(207, 583);
+            dockPanelRight.Text = "椤圭洰灞炴��";
             // 
             // controlContainer1
             // 
             controlContainer1.Controls.Add(homeXhsProjectPropertyCtrl1);
-            controlContainer1.Location = new Point(1, 34);
+            controlContainer1.Location = new Point(1, 23);
+            controlContainer1.Margin = new Padding(2);
             controlContainer1.Name = "controlContainer1";
-            controlContainer1.Size = new Size(298, 882);
+            controlContainer1.Size = new Size(206, 560);
             controlContainer1.TabIndex = 0;
             // 
             // dockPanelLeft
@@ -275,18 +330,20 @@
             dockPanelLeft.Dock = DevExpress.XtraBars.Docking.DockingStyle.Left;
             dockPanelLeft.ID = new Guid("fba93cbc-dfe6-4982-8aee-be8baff1ea68");
             dockPanelLeft.Location = new Point(0, 0);
+            dockPanelLeft.Margin = new Padding(2);
             dockPanelLeft.Name = "dockPanelLeft";
             dockPanelLeft.Options.ShowCloseButton = false;
-            dockPanelLeft.OriginalSize = new Size(294, 200);
-            dockPanelLeft.Size = new Size(294, 916);
+            dockPanelLeft.OriginalSize = new Size(191, 200);
+            dockPanelLeft.Size = new Size(191, 583);
             dockPanelLeft.Text = "椤圭洰鍒楄〃";
             // 
             // dockPanel1_Container
             // 
             dockPanel1_Container.Controls.Add(homeXhsProjectTreeListCtrl1);
-            dockPanel1_Container.Location = new Point(0, 34);
+            dockPanel1_Container.Location = new Point(0, 23);
+            dockPanel1_Container.Margin = new Padding(2);
             dockPanel1_Container.Name = "dockPanel1_Container";
-            dockPanel1_Container.Size = new Size(293, 882);
+            dockPanel1_Container.Size = new Size(190, 560);
             dockPanel1_Container.TabIndex = 0;
             // 
             // dockManager1
@@ -296,69 +353,26 @@
             dockManager1.Style = DevExpress.XtraBars.Docking2010.Views.DockingViewStyle.Light;
             dockManager1.TopZIndexControls.AddRange(new string[] { "DevExpress.XtraBars.BarDockControl", "DevExpress.XtraBars.StandaloneBarDockControl", "System.Windows.Forms.MenuStrip", "System.Windows.Forms.StatusStrip", "System.Windows.Forms.StatusBar", "DevExpress.XtraBars.Ribbon.RibbonStatusBar", "DevExpress.XtraBars.Ribbon.RibbonControl", "DevExpress.XtraBars.Navigation.OfficeNavigationBar", "DevExpress.XtraBars.Navigation.TileNavPane", "DevExpress.XtraBars.TabFormControl", "DevExpress.XtraBars.FluentDesignSystem.FluentDesignFormControl", "DevExpress.XtraBars.ToolbarForm.ToolbarFormControl" });
             // 
-            // layoutViewCard1
-            // 
-            layoutViewCard1.CustomizationFormText = "TemplateCard";
-            layoutViewCard1.GroupBordersVisible = false;
-            layoutViewCard1.GroupStyle = DevExpress.Utils.GroupStyle.Light;
-            layoutViewCard1.HeaderButtonsLocation = DevExpress.Utils.GroupElementLocation.AfterText;
-            layoutViewCard1.Items.AddRange(new DevExpress.XtraLayout.BaseLayoutItem[] { layoutViewField_colCount, layoutViewField_colPicture, layoutViewField_colName });
-            layoutViewCard1.Name = "layoutViewCard1";
-            layoutViewCard1.OptionsItemText.TextToControlDistance = 3;
-            layoutViewCard1.Padding = new DevExpress.XtraLayout.Utils.Padding(4, 4, 4, 4);
-            layoutViewCard1.Text = "TemplateCard";
-            // 
-            // layoutViewField_colCount
-            // 
-            layoutViewField_colCount.ContentHorzAlignment = DevExpress.Utils.HorzAlignment.Center;
-            layoutViewField_colCount.ContentVertAlignment = DevExpress.Utils.VertAlignment.Center;
-            layoutViewField_colCount.EditorPreferredWidth = 151;
-            layoutViewField_colCount.Location = new Point(133, 36);
-            layoutViewField_colCount.Name = "layoutViewField_colCount";
-            layoutViewField_colCount.Padding = new DevExpress.XtraLayout.Utils.Padding(4, 4, 4, 4);
-            layoutViewField_colCount.Size = new Size(159, 65);
-            layoutViewField_colCount.TextSize = new Size(0, 0);
-            layoutViewField_colCount.TextVisible = false;
-            // 
-            // layoutViewField_colPicture
-            // 
-            layoutViewField_colPicture.EditorPreferredWidth = 125;
-            layoutViewField_colPicture.Location = new Point(0, 0);
-            layoutViewField_colPicture.Name = "layoutViewField_colPicture";
-            layoutViewField_colPicture.Padding = new DevExpress.XtraLayout.Utils.Padding(4, 4, 4, 4);
-            layoutViewField_colPicture.Size = new Size(133, 101);
-            layoutViewField_colPicture.StartNewLine = true;
-            layoutViewField_colPicture.TextSize = new Size(0, 0);
-            layoutViewField_colPicture.TextVisible = false;
-            // 
-            // layoutViewField_colName
-            // 
-            layoutViewField_colName.ContentHorzAlignment = DevExpress.Utils.HorzAlignment.Center;
-            layoutViewField_colName.ContentVertAlignment = DevExpress.Utils.VertAlignment.Center;
-            layoutViewField_colName.EditorPreferredWidth = 151;
-            layoutViewField_colName.Location = new Point(133, 0);
-            layoutViewField_colName.Name = "layoutViewField_colName";
-            layoutViewField_colName.Padding = new DevExpress.XtraLayout.Utils.Padding(4, 4, 4, 4);
-            layoutViewField_colName.Size = new Size(159, 36);
-            layoutViewField_colName.TextSize = new Size(0, 0);
-            layoutViewField_colName.TextVisible = false;
-            // 
             // HomeXhsProjectPage
             // 
             Appearance.BackColor = SystemColors.Control;
             Appearance.Options.UseBackColor = true;
-            AutoScaleDimensions = new SizeF(10F, 22F);
+            AutoScaleDimensions = new SizeF(7F, 14F);
             AutoScaleMode = AutoScaleMode.Font;
             Controls.Add(sidePanelBottom);
             Controls.Add(sidePanel1);
-            Margin = new Padding(6, 8, 6, 8);
+            Margin = new Padding(4, 5, 4, 5);
             Name = "HomeXhsProjectPage";
-            Size = new Size(1519, 1064);
+            Size = new Size(1063, 677);
             ((ISupportInitialize)svgImg32).EndInit();
             sidePanel1.ResumeLayout(false);
             ((ISupportInitialize)gridControl1).EndInit();
             ((ISupportInitialize)layoutView1).EndInit();
+            ((ISupportInitialize)layoutViewField_colName).EndInit();
+            ((ISupportInitialize)layoutViewField_colCount).EndInit();
             ((ISupportInitialize)repPicEdit).EndInit();
+            ((ISupportInitialize)layoutViewField_colPicture).EndInit();
+            ((ISupportInitialize)layoutViewCard1).EndInit();
             ((ISupportInitialize)gridView1).EndInit();
             sidePanelBottom.ResumeLayout(false);
             dockPanelFill.ResumeLayout(false);
@@ -368,10 +382,6 @@
             dockPanelLeft.ResumeLayout(false);
             dockPanel1_Container.ResumeLayout(false);
             ((ISupportInitialize)dockManager1).EndInit();
-            ((ISupportInitialize)layoutViewCard1).EndInit();
-            ((ISupportInitialize)layoutViewField_colCount).EndInit();
-            ((ISupportInitialize)layoutViewField_colPicture).EndInit();
-            ((ISupportInitialize)layoutViewField_colName).EndInit();
             ResumeLayout(false);
         }
 
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.cs
index 5f365f2..7599e9b 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/01-home/HomeXhsProjectPage.cs
@@ -1,4 +1,6 @@
 锘縰sing DevExpress.Utils.Svg;
+using HStation.WinFrmUI.Xhs.PumpProduct;
+using Yw.WinFrmUI.Page;
 
 namespace HStation.WinFrmUI
 {
@@ -23,9 +25,10 @@
             public SvgImage Image { get; set; }
         }
 
-
         private Lazy<BLL.XhsProjectStd> _bllProjectStd = new(() => new BLL.XhsProjectStd());
         private List<XhsProjectStdDto> _allProjectList = null;
+
+        private Lazy<BLL.PumpMain> _bllPump = new(() => new BLL.PumpMain());
 
         /// <summary>
         /// 鍒濆鍖栨暟鎹簮
@@ -33,34 +36,31 @@
         public override async void InitialDataSource()
         {
             _allProjectList = await _bllProjectStd.Value.GetAll();
-
+            var allPump = await _bllPump.Value.GetAll();
             var vm = new CurrentViewModel()
             {
                 Name = "椤圭洰鏁伴噺",
                 Count = _allProjectList?.Count ?? 0,
-                Image =  ImageLib.Project
+                Image = ImageLib.Project
             };
-        
 
             var vm2 = new CurrentViewModel()
             {
                 Name = "姘存车鍨嬪彿鏁伴噺",
-                Count = 999,
+                Count = allPump?.Count ?? 0,
                 Image = ImageLib.PumpMain
-
             };
-             
+
             var vm3 = new CurrentViewModel()
             {
                 Name = "闃�闂ㄥ瀷鍙锋暟閲�",
-                Count = 666,
+                Count = 0,
                 Image = ImageLib.Valve
             };
 
             var list = new List<CurrentViewModel>() { vm, vm2, vm3 };
             this.gridControl1.DataSource = list;
             this.gridControl1.RefreshDataSource();
-
 
             this.mapViewProjectListContainer1.LoadCompletedEvent += MapViewProjectListContainer1_LoadCompletedEvent;
             await this.mapViewProjectListContainer1.InitialContainer();
@@ -116,8 +116,6 @@
                 //var page = new XhsProjectSimulationMgrPage();
                 CreatePage(page, guid);
             }
-
-
         }
 
         //鍒锋柊鏁版嵁浜嬩欢
@@ -125,6 +123,45 @@
         {
             RefreshData();
         }
-         
+
+        //鍗曞嚮鏁伴噺鎬昏璺宠浆
+        private void layoutView1_FieldValueClick(object sender, DevExpress.XtraGrid.Views.Layout.Events.FieldValueClickEventArgs e)
+        {
+            if (e.Column.Caption != "鍚嶇О")
+                return;
+            switch (e.FieldValue)
+            {
+                case "椤圭洰鏁伴噺":
+                    var guid = new PageGuid()
+                    {
+                        Modular = "Xhs",
+                        MoudingType = eMoudingType.Tab,
+                        Function = "ProjectMgr",
+                    };
+                    if (!IsExistPage(guid, true))
+                    {
+                        var page = new XhsProjectMgrPage();
+                        CreatePage(page, guid);
+                    }
+                    break;
+
+                case "姘存车鍨嬪彿鏁伴噺":
+                    var pumpGuid = new PageGuid()
+                    {
+                        Modular = "Xhs",
+                        MoudingType = eMoudingType.Tab,
+                        Function = "PumpMgr",
+                    };
+                    if (!IsExistPage(pumpGuid, true))
+                    {
+                        var page = new PumpProductMainPanel();
+                        CreatePage(page, pumpGuid);
+                    }
+                    break;
+
+                case "闃�闂ㄥ瀷鍙锋暟閲�":
+                    break;
+            }
+        }
     }
-}
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.Designer.cs
index aa13cbd..31dc1ca 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.Designer.cs
@@ -1,4 +1,6 @@
-锘縩amespace HStation.WinFrmUI
+锘縰sing System.Security.Cryptography.X509Certificates;
+
+namespace HStation.WinFrmUI
 {
     partial class ImportXhsProjectDlg
     {
@@ -43,6 +45,7 @@
             generateXhsProjectWizardPage = new GenerateXhsProjectWizardPage();
             navPageImportCompleted = new DevExpress.XtraBars.Navigation.NavigationPage();
             importXhsProjectCompletedWizardPage = new ImportXhsProjectCompletedCtrl();
+            navigationPage1 = new DevExpress.XtraBars.Navigation.NavigationPage();
             stepProgressBar1 = new DevExpress.XtraEditors.StepProgressBar();
             stepPbSelectModelFile = new DevExpress.XtraEditors.StepProgressBarItem();
             stepPbSetMapLocation = new DevExpress.XtraEditors.StepProgressBarItem();
@@ -54,6 +57,7 @@
             itemForPrev = new DevExpress.XtraLayout.LayoutControlItem();
             emptySpaceItem1 = new DevExpress.XtraLayout.EmptySpaceItem();
             itemForComplete = new DevExpress.XtraLayout.LayoutControlItem();
+            projectResultShowPanel1 = new Xhs.ProjectResultShowPanel();
             ((ISupportInitialize)layoutControl1).BeginInit();
             layoutControl1.SuspendLayout();
             ((ISupportInitialize)navigationFrame1).BeginInit();
@@ -62,6 +66,7 @@
             navPageSetMapLocation.SuspendLayout();
             navPageGenerateProject.SuspendLayout();
             navPageImportCompleted.SuspendLayout();
+            navigationPage1.SuspendLayout();
             ((ISupportInitialize)stepProgressBar1).BeginInit();
             ((ISupportInitialize)Root).BeginInit();
             ((ISupportInitialize)layoutControlItem1).BeginInit();
@@ -104,7 +109,7 @@
             // 
             // btnPrev
             // 
-            btnPrev.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Question;
+            btnPrev.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Warning;
             btnPrev.Appearance.Options.UseBackColor = true;
             btnPrev.Location = new Point(625, 661);
             btnPrev.Name = "btnPrev";
@@ -116,7 +121,7 @@
             // 
             // btnNext
             // 
-            btnNext.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Success;
+            btnNext.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Question;
             btnNext.Appearance.Options.UseBackColor = true;
             btnNext.Location = new Point(745, 661);
             btnNext.Name = "btnNext";
@@ -128,7 +133,7 @@
             // 
             // btnCancel
             // 
-            btnCancel.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Warning;
+            btnCancel.Appearance.BackColor = DevExpress.LookAndFeel.DXSkinColors.FillColors.Danger;
             btnCancel.Appearance.Options.UseBackColor = true;
             btnCancel.Location = new Point(865, 661);
             btnCancel.Name = "btnCancel";
@@ -144,9 +149,10 @@
             navigationFrame1.Controls.Add(navPageSetMapLocation);
             navigationFrame1.Controls.Add(navPageGenerateProject);
             navigationFrame1.Controls.Add(navPageImportCompleted);
+            navigationFrame1.Controls.Add(navigationPage1);
             navigationFrame1.Location = new Point(12, 120);
             navigationFrame1.Name = "navigationFrame1";
-            navigationFrame1.Pages.AddRange(new DevExpress.XtraBars.Navigation.NavigationPageBase[] { navPageInputProjectInfo, navPageSetMapLocation, navPageGenerateProject, navPageImportCompleted });
+            navigationFrame1.Pages.AddRange(new DevExpress.XtraBars.Navigation.NavigationPageBase[] { navPageInputProjectInfo, navPageSetMapLocation, navPageGenerateProject, navPageImportCompleted, navigationPage1 });
             navigationFrame1.SelectedPage = navPageInputProjectInfo;
             navigationFrame1.Size = new Size(1089, 537);
             navigationFrame1.TabIndex = 5;
@@ -214,6 +220,13 @@
             importXhsProjectCompletedWizardPage.Size = new Size(1089, 537);
             importXhsProjectCompletedWizardPage.TabIndex = 0;
             // 
+            // navigationPage1
+            // 
+            navigationPage1.Caption = "navigationPage1";
+            navigationPage1.Controls.Add(projectResultShowPanel1);
+            navigationPage1.Name = "navigationPage1";
+            navigationPage1.Size = new Size(1089, 537);
+            // 
             // stepProgressBar1
             // 
             stepProgressBar1.ContentAlignment = ContentAlignment.MiddleLeft;
@@ -223,7 +236,8 @@
             stepProgressBar1.Items.Add(stepPbSetMapLocation);
             stepProgressBar1.Location = new Point(12, 12);
             stepProgressBar1.Name = "stepProgressBar1";
-            stepProgressBar1.SelectedItemIndex = 1;
+            stepProgressBar1.SelectedItemIndex = 0;
+            stepProgressBar1.ShadowDrawMode = DevExpress.XtraEditors.StepProgressBarShadowDrawMode.ActiveElements;
             stepProgressBar1.Size = new Size(1089, 104);
             stepProgressBar1.StyleController = layoutControl1;
             stepProgressBar1.TabIndex = 4;
@@ -231,15 +245,18 @@
             // 
             // stepPbSelectModelFile
             // 
-            stepPbSelectModelFile.ContentBlock2.Caption = "褰曞叆椤圭洰淇℃伅";
+            stepPbSelectModelFile.ContentBlock1.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepPbSelectModelFile.ContentBlock1.ActiveStateImageOptions.SvgImage");
+            stepPbSelectModelFile.ContentBlock1.InactiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepPbSelectModelFile.ContentBlock1.InactiveStateImageOptions.SvgImage");
+            stepPbSelectModelFile.ContentBlock2.Caption = "鍩烘湰淇℃伅";
             stepPbSelectModelFile.Name = "stepPbSelectModelFile";
             stepPbSelectModelFile.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepPbSetMapLocation
             // 
+            stepPbSetMapLocation.ContentBlock1.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepPbSetMapLocation.ContentBlock1.ActiveStateImageOptions.SvgImage");
+            stepPbSetMapLocation.ContentBlock1.InactiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepPbSetMapLocation.ContentBlock1.InactiveStateImageOptions.SvgImage");
             stepPbSetMapLocation.ContentBlock2.Caption = "璁剧疆鍦板浘浣嶇疆";
             stepPbSetMapLocation.Name = "stepPbSetMapLocation";
-            stepPbSetMapLocation.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // Root
             // 
@@ -324,6 +341,14 @@
             itemForComplete.TextSize = new Size(0, 0);
             itemForComplete.TextVisible = false;
             // 
+            // projectResultShowPanel1
+            // 
+            projectResultShowPanel1.Dock = DockStyle.Fill;
+            projectResultShowPanel1.Location = new Point(0, 0);
+            projectResultShowPanel1.Name = "projectResultShowPanel1";
+            projectResultShowPanel1.Size = new Size(1089, 537);
+            projectResultShowPanel1.TabIndex = 0;
+            // 
             // ImportXhsProjectDlg
             // 
             AutoScaleDimensions = new SizeF(7F, 14F);
@@ -342,6 +367,7 @@
             navPageSetMapLocation.ResumeLayout(false);
             navPageGenerateProject.ResumeLayout(false);
             navPageImportCompleted.ResumeLayout(false);
+            navigationPage1.ResumeLayout(false);
             ((ISupportInitialize)stepProgressBar1).EndInit();
             ((ISupportInitialize)Root).EndInit();
             ((ISupportInitialize)layoutControlItem1).EndInit();
@@ -381,5 +407,7 @@
         private ImportXhsProjectCompletedCtrl importXhsProjectCompletedWizardPage;
         private DevExpress.XtraEditors.SimpleButton btnComplete;
         private DevExpress.XtraLayout.LayoutControlItem itemForComplete;
+        private DevExpress.XtraBars.Navigation.NavigationPage navigationPage1;
+        private Xhs.ProjectResultShowPanel projectResultShowPanel1;
     }
 }
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.cs
index 0862469..5155937 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.cs
@@ -1,5 +1,7 @@
 锘縰sing DevExpress.XtraEditors;
 using DevExpress.XtraLayout.Utils;
+using HStation.WinFrmUI.Xhs;
+using HStation.WinFrmUI.Xhs.Core.Properties;
 
 namespace HStation.WinFrmUI
 {
@@ -37,7 +39,8 @@
                 this.inputXhsProjectInfoWizardPage,
                 this.setXhsProjectMapLocationWizardPage,
                 this.generateXhsProjectWizardPage,
-                this.importXhsProjectCompletedWizardPage
+                this.importXhsProjectCompletedWizardPage,
+                this.projectResultShowPanel1
             });
         }
 
@@ -52,10 +55,16 @@
                 }
             }
             StepProgressBarItem stepPbInputProjectInfo = new StepProgressBarItem();
+            stepPbInputProjectInfo.ContentBlock1.ActiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("productquickshippments");
+            stepPbInputProjectInfo.ContentBlock1.InactiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("productquickshippments");
             stepPbInputProjectInfo.ContentBlock2.Caption = "鑷姩鐢熸垚椤圭洰";
             StepProgressBarItem stepPbImportComleted = new StepProgressBarItem();
             stepPbImportComleted.ContentBlock2.Caption = "椤圭洰瀵煎叆瀹屾垚";
+            stepPbImportComleted.ContentBlock1.ActiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("check");
+            stepPbImportComleted.ContentBlock1.InactiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("check");
             StepProgressBarItem stepGenerateProject = new StepProgressBarItem();
+            stepGenerateProject.ContentBlock1.ActiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("showallfieldresults");
+            stepGenerateProject.ContentBlock1.InactiveStateImageOptions.SvgImage = DevExpress.Images.ImageResourceCache.Default.GetSvgImageById("showallfieldresults");
             stepGenerateProject.ContentBlock2.Caption = "椤圭洰灞曠ず缁撴灉";
             this.stepProgressBar1.Items.Add(stepPbInputProjectInfo);
             this.stepProgressBar1.Items.Add(stepPbImportComleted);
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.resx b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.resx
index 656fe2b..efaad70 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.resx
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectDlg.resx
@@ -137,4 +137,92 @@
         ZWVuIiAvPg0KICA8L2c+DQo8L3N2Zz4L
 </value>
   </data>
+  <data name="stepPbSelectModelFile.ContentBlock1.ActiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAP4DAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
+        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLlllbGxvd3tmaWxsOiNGRkIxMTU7fQoJ
+        LlJlZHtmaWxsOiNEMTFDMUM7fQoJLkJsdWV7ZmlsbDojMTE3N0Q3O30KCS5HcmVlbntmaWxsOiMwMzlD
+        MjM7fQoJLkJsYWNre2ZpbGw6IzcyNzI3Mjt9CgkuV2hpdGV7ZmlsbDojRkZGRkZGO30KCS5zdDB7b3Bh
+        Y2l0eTowLjU7fQoJLnN0MXtkaXNwbGF5Om5vbmU7fQoJLnN0MntkaXNwbGF5OmlubGluZTtmaWxsOiMw
+        MzlDMjM7fQoJLnN0M3tkaXNwbGF5OmlubGluZTtmaWxsOiNEMTFDMUM7fQoJLnN0NHtkaXNwbGF5Omlu
+        bGluZTtmaWxsOiM3MjcyNzI7fQo8L3N0eWxlPg0KICA8ZyBpZD0iRW1wbG95ZWVUYXNrTGlzdCI+DQog
+        ICAgPHBhdGggZD0iTTI5LDBIM0MyLjUsMCwyLDAuNSwyLDF2MjhjMCwwLjUsMC41LDEsMSwxaDI2YzAu
+        NSwwLDEtMC41LDEtMVYxQzMwLDAuNSwyOS41LDAsMjksMHogTTI4LDI4SDRWMmgyNFYyOHoiIGNsYXNz
+        PSJCbGFjayIgLz4NCiAgICA8ZyBjbGFzcz0ic3QwIj4NCiAgICAgIDxwYXRoIGQ9Ik0yNCw4SDEyVjZo
+        MTJWOHogTTI0LDEwSDEydjJoMTJWMTB6IE0yNCwxNEgxMnYyaDEyVjE0eiBNMjQsMThIMTJ2MmgxMlYx
+        OHogTTI0LDIySDEydjJoMTJWMjJ6IiBjbGFzcz0iQmxhY2siIC8+DQogICAgPC9nPg0KICAgIDxwYXRo
+        IGQ9Ik0xMCw4SDhWNmgyVjh6IE0xMCwxMEg4djJoMlYxMHogTTEwLDE0SDh2MmgyVjE0eiBNMTAsMThI
+        OHYyaDJWMTh6IE0xMCwyMkg4djJoMlYyMnoiIGNsYXNzPSJCbHVlIiAvPg0KICA8L2c+DQo8L3N2Zz4L
+</value>
+  </data>
+  <data name="stepPbSelectModelFile.ContentBlock1.InactiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAPMDAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
+        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLlllbGxvd3tmaWxsOiNGRkIxMTU7fQoJ
+        LlJlZHtmaWxsOiNEMTFDMUM7fQoJLkJsdWV7ZmlsbDojMTE3N0Q3O30KCS5HcmVlbntmaWxsOiMwMzlD
+        MjM7fQoJLkJsYWNre2ZpbGw6IzcyNzI3Mjt9CgkuV2hpdGV7ZmlsbDojRkZGRkZGO30KCS5zdDB7b3Bh
+        Y2l0eTowLjU7fQoJLnN0MXtkaXNwbGF5Om5vbmU7fQoJLnN0MntkaXNwbGF5OmlubGluZTtmaWxsOiMw
+        MzlDMjM7fQoJLnN0M3tkaXNwbGF5OmlubGluZTtmaWxsOiNEMTFDMUM7fQoJLnN0NHtkaXNwbGF5Omlu
+        bGluZTtmaWxsOiM3MjcyNzI7fQo8L3N0eWxlPg0KICA8ZyBpZD0iVGFza3MiPg0KICAgIDxwYXRoIGQ9
+        Ik0yOSwwSDNDMi41LDAsMiwwLjUsMiwxdjI4YzAsMC41LDAuNSwxLDEsMWgyNmMwLjUsMCwxLTAuNSwx
+        LTFWMUMzMCwwLjUsMjkuNSwwLDI5LDB6IE0yOCwyOEg0VjJoMjRWMjh6IiBjbGFzcz0iQmxhY2siIC8+
+        DQogICAgPGcgY2xhc3M9InN0MCI+DQogICAgICA8cGF0aCBkPSJNMjQsOEgxMlY2aDEyVjh6IE0yNCwx
+        MEgxMnYyaDEyVjEweiBNMjQsMTRIMTJ2MmgxMlYxNHogTTI0LDE4SDEydjJoMTJWMTh6IE0yNCwyMkgx
+        MnYyaDEyVjIyeiIgY2xhc3M9IkJsYWNrIiAvPg0KICAgIDwvZz4NCiAgICA8cGF0aCBkPSJNMTAsOEg4
+        VjZoMlY4eiBNMTAsMTBIOHYyaDJWMTB6IE0xMCwxNEg4djJoMlYxNHogTTEwLDE4SDh2MmgyVjE4eiBN
+        MTAsMjJIOHYyaDJWMjJ6IiBjbGFzcz0iQmx1ZSIgLz4NCiAgPC9nPg0KPC9zdmc+Cw==
+</value>
+  </data>
+  <data name="stepPbSetMapLocation.ContentBlock1.ActiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAP4CAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
+        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkdyZWVue2ZpbGw6IzAzOUMyMzt9Cgku
+        QmxhY2t7ZmlsbDojNzI3MjcyO30KCS5SZWR7ZmlsbDojRDExQzFDO30KCS5ZZWxsb3d7ZmlsbDojRkZC
+        MTE1O30KCS5CbHVle2ZpbGw6IzExNzdENzt9CgkuV2hpdGV7ZmlsbDojRkZGRkZGO30KCS5zdDB7b3Bh
+        Y2l0eTowLjU7fQoJLnN0MXtvcGFjaXR5OjAuNzU7fQo8L3N0eWxlPg0KICA8ZyBpZD0iSW5zZXJ0QnVi
+        YmxlTWFwIj4NCiAgICA8cGF0aCBkPSJNMjEuNywxMC4zYzIuNSwwLjcsNC4zLDMsNC4zLDUuN2MwLDMu
+        My0yLjcsNi02LDZ2Ny4ybC04LTh2LTcuM2MtMi41LTAuNC00LjYtMi4xLTUuNS00LjRMNCwxMnYyMGw4
+        LThsOCw4ICAgbDgtOFY0TDIxLjcsMTAuM3oiIGNsYXNzPSJCbHVlIiAvPg0KICAgIDxjaXJjbGUgY3g9
+        IjEzIiBjeT0iNyIgcj0iNSIgY2xhc3M9IkdyZWVuIiAvPg0KICAgIDxjaXJjbGUgY3g9IjIwIiBjeT0i
+        MTYiIHI9IjQiIGNsYXNzPSJZZWxsb3ciIC8+DQogIDwvZz4NCjwvc3ZnPgs=
+</value>
+  </data>
+  <data name="stepPbSetMapLocation.ContentBlock1.InactiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAP4CAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
+        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkdyZWVue2ZpbGw6IzAzOUMyMzt9Cgku
+        QmxhY2t7ZmlsbDojNzI3MjcyO30KCS5SZWR7ZmlsbDojRDExQzFDO30KCS5ZZWxsb3d7ZmlsbDojRkZC
+        MTE1O30KCS5CbHVle2ZpbGw6IzExNzdENzt9CgkuV2hpdGV7ZmlsbDojRkZGRkZGO30KCS5zdDB7b3Bh
+        Y2l0eTowLjU7fQoJLnN0MXtvcGFjaXR5OjAuNzU7fQo8L3N0eWxlPg0KICA8ZyBpZD0iSW5zZXJ0QnVi
+        YmxlTWFwIj4NCiAgICA8cGF0aCBkPSJNMjEuNywxMC4zYzIuNSwwLjcsNC4zLDMsNC4zLDUuN2MwLDMu
+        My0yLjcsNi02LDZ2Ny4ybC04LTh2LTcuM2MtMi41LTAuNC00LjYtMi4xLTUuNS00LjRMNCwxMnYyMGw4
+        LThsOCw4ICAgbDgtOFY0TDIxLjcsMTAuM3oiIGNsYXNzPSJCbHVlIiAvPg0KICAgIDxjaXJjbGUgY3g9
+        IjEzIiBjeT0iNyIgcj0iNSIgY2xhc3M9IkdyZWVuIiAvPg0KICAgIDxjaXJjbGUgY3g9IjIwIiBjeT0i
+        MTYiIHI9IjQiIGNsYXNzPSJZZWxsb3ciIC8+DQogIDwvZz4NCjwvc3ZnPgs=
+</value>
+  </data>
 </root>
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectHelper.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectHelper.cs
index d77b254..a998190 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectHelper.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/00-core/ImportXhsProjectHelper.cs
@@ -41,7 +41,79 @@
 
             #endregion 绗竴姝� 涓存椂鏂囦欢澶勭悊锛堣繘搴�5%锛�
 
-            #region 绗簩姝� 鍘嬬缉鏂囦欢瑙f瀽 锛堣繘搴�10%锛�
+            #region 绗簩姝� 鍒涘缓椤圭洰锛堣繘搴� 10%锛�
+
+            feedBackMsg?.Invoke("姝e湪鍒涘缓椤圭洰...");
+
+            var bllXhsProjectExtensions = new Lazy<BLL.XhsProjectExtensions>(() => new BLL.XhsProjectExtensions());
+
+            var project = new Vmo.Xhs.XhsProjectExtensions();
+            project.NO = vm.NO;
+            project.Name = vm.Name;
+            project.Address = vm.Address;
+            project.Customer = vm.Customer;
+            project.Flags = vm.Flags;
+            project.TagName = vm.TagName;
+            project.Description = vm.Description;
+
+            project.SiteList = new List<Vmo.Xhs.XhsProjectSite>() {
+                new Vmo.Xhs.XhsProjectSite(){
+                    Name=vm.Name,
+                    Description=vm.Description
+                }
+            };
+
+            var projectId = await bllXhsProjectExtensions.Value.Insert(project);
+            if (projectId < 1)
+            {
+                feedBackMsg?.Invoke("椤圭洰鍒涘缓澶辫触锛侊紒锛�");
+                return false;
+            }
+
+            feedBackMsg?.Invoke("椤圭洰鍒涘缓鎴愬姛銆傘�傘��");
+
+            vm.ProjectID = projectId;
+
+            feedBackProgress?.Invoke(100, 10);
+
+            #endregion 绗簩姝� 鍒涘缓椤圭洰锛堣繘搴� 10%锛�
+
+            #region 绗笁姝� 璁剧疆鍦板浘浣嶇疆锛堣繘搴� 20%锛�
+
+            feedBackMsg?.Invoke("姝e湪璁剧疆鍦板浘浣嶇疆...");
+
+            if (vm.Location != null)
+            {
+                var mapInfo = new Yw.Vmo.Map.MapInfo();
+                mapInfo.ObjectType = HStation.Xhs.DataType.XhsProject;
+                mapInfo.ObjectID = projectId;
+                mapInfo.ObjectName = project.Name;
+                mapInfo.Purpose = Yw.Map.Purpose.Location;
+                mapInfo.Kind = Yw.Map.Kind.Gaodei;
+                mapInfo.Shape = Yw.Map.Shape.Marker;
+                mapInfo.Position = vm.Location.ToJson();
+
+                var mapInfoId = await new Yw.BLL.MapInfo().Insert(mapInfo);
+                if (mapInfoId < 1)
+                {
+                    feedBackMsg?.Invoke("璁剧疆鍦板浘浣嶇疆澶辫触锛侊紒锛�");
+                }
+                else
+                {
+                    vm.MapInfoID = mapInfoId;
+                    feedBackMsg?.Invoke("璁剧疆鍦板浘浣嶇疆鎴愬姛銆傘�傘��");
+                }
+            }
+            else
+            {
+                feedBackMsg?.Invoke("鏈缃湴鍥句綅缃俊鎭紒锛侊紒");
+            }
+
+            feedBackProgress?.Invoke(100, 20);
+
+            #endregion 绗笁姝� 璁剧疆鍦板浘浣嶇疆锛堣繘搴� 20%锛�
+
+            #region 绗洓姝� 鍘嬬缉鏂囦欢瑙f瀽 锛堣繘搴�25%锛�
 
             msg = "姝e湪瑙f瀽妯″瀷鏂囦欢...";
             feedBackMsg?.Invoke(msg);
@@ -62,11 +134,11 @@
 
             feedBackMsg?.Invoke("妯″瀷鏂囦欢瑙f瀽鎴愬姛銆傘�傘��");
 
-            feedBackProgress?.Invoke(100, 10);
+            feedBackProgress?.Invoke(100, 25);
 
-            #endregion 绗簩姝� 鍘嬬缉鏂囦欢瑙f瀽 锛堣繘搴�10%锛�
+            #endregion 绗洓姝� 鍘嬬缉鏂囦欢瑙f瀽 锛堣繘搴�25%锛�
 
-            #region 绗笁姝� 瑙f瀽姘村姏缁撴瀯鏂囦欢 锛堣繘搴�15%锛�
+            #region 绗簲姝� 瑙f瀽姘村姏缁撴瀯鏂囦欢 锛堣繘搴�30%锛�
 
             feedBackMsg?.Invoke("姝e湪瑙f瀽姘村姏缁撴瀯鏂囦欢...");
             var jsonFileInfo = allFileInfoList.Where(x => x.Extension == ".json").FirstOrDefault();
@@ -100,50 +172,13 @@
 
             feedBackMsg?.Invoke("姘村姏缁撴瀯鏂囦欢瑙f瀽鎴愬姛銆傘�傘��");
 
-            feedBackProgress?.Invoke(100, 15);
+            feedBackProgress?.Invoke(100, 30);
 
             vm.HydroID = hydroId;
 
-            #endregion 绗笁姝� 瑙f瀽姘村姏缁撴瀯鏂囦欢 锛堣繘搴�15%锛�
+            #endregion 绗簲姝� 瑙f瀽姘村姏缁撴瀯鏂囦欢 锛堣繘搴�30%锛�
 
-            #region 绗洓姝� 鍒涘缓椤圭洰锛堣繘搴� 20%锛�
-
-            feedBackMsg?.Invoke("姝e湪鍒涘缓椤圭洰...");
-
-            var bllXhsProjectExtensions = new Lazy<BLL.XhsProjectExtensions>(() => new BLL.XhsProjectExtensions());
-
-            var project = new Vmo.Xhs.XhsProjectExtensions();
-            project.NO = vm.NO;
-            project.Name = vm.Name;
-            project.Address = vm.Address;
-            project.Customer = vm.Customer;
-            project.Flags = vm.Flags;
-            project.TagName = vm.TagName;
-            project.Description = vm.Description;
-
-            project.SiteList = new List<Vmo.Xhs.XhsProjectSite>() {
-                new Vmo.Xhs.XhsProjectSite(){
-                    Name=vm.Name,
-                    Description=vm.Description
-                }
-            };
-
-            var projectId = await bllXhsProjectExtensions.Value.Insert(project);
-            if (projectId < 1)
-            {
-                feedBackMsg?.Invoke("椤圭洰鍒涘缓澶辫触锛侊紒锛�");
-                return false;
-            }
-
-            feedBackMsg?.Invoke("椤圭洰鍒涘缓鎴愬姛銆傘�傘��");
-
-            vm.ProjectID = projectId;
-
-            feedBackProgress?.Invoke(100, 20);
-
-            #endregion 绗洓姝� 鍒涘缓椤圭洰锛堣繘搴� 20%锛�
-
-            #region 绗簲姝� 鍏宠仈姘村姏缁撴瀯妯″瀷锛堣繘搴� 25%锛�
+            #region 绗叚姝� 鍏宠仈姘村姏缁撴瀯妯″瀷锛堣繘搴� 40%锛�
 
             var bllXhsProjectSite = new BLL.XhsProjectSiteStd();
             var projectSite = await bllXhsProjectSite.GetDefaultByProjectID(projectId);
@@ -178,44 +213,9 @@
 
             feedBackMsg?.Invoke("鍏宠仈姘村姏缁撴瀯妯″瀷鎴愬姛銆傘�傘��");
 
-            feedBackProgress?.Invoke(100, 25);
+            feedBackProgress?.Invoke(100, 40);
 
-            #endregion 绗簲姝� 鍏宠仈姘村姏缁撴瀯妯″瀷锛堣繘搴� 25%锛�
-
-            #region 绗叚姝� 璁剧疆鍦板浘浣嶇疆锛堣繘搴� 30%锛�
-
-            feedBackMsg?.Invoke("姝e湪璁剧疆鍦板浘浣嶇疆...");
-
-            if (vm.Location != null)
-            {
-                var mapInfo = new Yw.Vmo.Map.MapInfo();
-                mapInfo.ObjectType = HStation.Xhs.DataType.XhsProject;
-                mapInfo.ObjectID = projectId;
-                mapInfo.ObjectName = project.Name;
-                mapInfo.Purpose = Yw.Map.Purpose.Location;
-                mapInfo.Kind = Yw.Map.Kind.Gaodei;
-                mapInfo.Shape = Yw.Map.Shape.Marker;
-                mapInfo.Position = vm.Location.ToJson();
-
-                var mapInfoId = await new Yw.BLL.MapInfo().Insert(mapInfo);
-                if (mapInfoId < 1)
-                {
-                    feedBackMsg?.Invoke("璁剧疆鍦板浘浣嶇疆澶辫触锛侊紒锛�");
-                }
-                else
-                {
-                    vm.MapInfoID = mapInfoId;
-                    feedBackMsg?.Invoke("璁剧疆鍦板浘浣嶇疆鎴愬姛銆傘�傘��");
-                }
-            }
-            else
-            {
-                feedBackMsg?.Invoke("鏈缃湴鍥句綅缃俊鎭紒锛侊紒");
-            }
-
-            feedBackProgress?.Invoke(100, 30);
-
-            #endregion 绗叚姝� 璁剧疆鍦板浘浣嶇疆锛堣繘搴� 30%锛�
+            #endregion 绗叚姝� 鍏宠仈姘村姏缁撴瀯妯″瀷锛堣繘搴� 40%锛�
 
             #region 绗竷姝� 涓婁紶Revit妯″瀷鏂囦欢锛堣繘搴� 45%锛�
 
@@ -299,7 +299,7 @@
 
             #endregion 绗節姝� 鍏宠仈Bimface鏂囦欢锛堣繘搴� 55%锛�
 
-            #region 绗節姝� 鍙戣捣bimface杞崲锛堣繘搴� 80%锛�
+            #region 绗崄姝� 鍙戣捣bimface杞崲锛堣繘搴� 80%锛�
 
             feedBackMsg?.Invoke("姝e湪杩涜Bimface妯″瀷杞婚噺鍖�...");
             // var bimfaceTranslateStatus = await Yw.WinFrmUI.BimfaceHelper.TranslateRvtFile(bimfaceId);//鍙戣捣杞崲
@@ -327,9 +327,9 @@
 
             feedBackProgress?.Invoke(100, 80);
 
-            #endregion 绗節姝� 鍙戣捣bimface杞崲锛堣繘搴� 80%锛�
+            #endregion 绗崄姝� 鍙戣捣bimface杞崲锛堣繘搴� 80%锛�
 
-            #region 绗崄姝� 鏇存柊Bimface鏂囦欢鐘舵�侊紙杩涘害 90%锛�
+            #region 绗崄涓�姝� 鏇存柊Bimface鏂囦欢鐘舵�侊紙杩涘害 100%锛�
 
             feedBackMsg?.Invoke("姝e湪鏇存柊Bimface鏂囦欢鐘舵��...");
             bol = await bllBimfaceFile.UpdateFileStatus(bimfaceFileId, (int)Yw.Bimface.eFileStatus.ConvertSucceed);
@@ -344,30 +344,30 @@
                 return true;
             }
 
-            feedBackProgress?.Invoke(100, 90);
-
-            #endregion 绗崄姝� 鏇存柊Bimface鏂囦欢鐘舵�侊紙杩涘害 90%锛�
-
-            #region 绗崄涓�姝� 椤圭洰鍙戝竷锛堣繘搴� 100%锛�
-
-            feedBackMsg?.Invoke("姝e湪鍙戝竷椤圭洰...");
-            var bllXhsProject = new BLL.XhsProject();
-            bol = await bllXhsProject.Publish(projectId);
-            if (!bol)
-            {
-                feedBackMsg?.Invoke("椤圭洰鍙戝竷澶辫触...");
-            }
-            else
-            {
-                vm.IsPublished = true;
-                feedBackMsg?.Invoke("椤圭洰鍙戝竷鎴愬姛...");
-            }
-
             feedBackProgress?.Invoke(100, 100);
-            feedBackMsg?.Invoke("椤圭洰瀵煎叆缁撴潫銆傘�傘��");
+
+            #endregion 绗崄涓�姝� 鏇存柊Bimface鏂囦欢鐘舵�侊紙杩涘害 100%锛�
+
+            #region 寮冪敤  绗崄浜屾 椤圭洰鍙戝竷锛堣繘搴� 100%锛�
+
+            /*    feedBackMsg?.Invoke("姝e湪鍙戝竷椤圭洰...");
+                var bllXhsProject = new BLL.XhsProject();
+                bol = await bllXhsProject.Publish(projectId);
+                if (!bol)
+                {
+                    feedBackMsg?.Invoke("椤圭洰鍙戝竷澶辫触...");
+                }
+                else
+                {
+                    vm.IsPublished = true;
+                    feedBackMsg?.Invoke("椤圭洰鍙戝竷鎴愬姛...");
+                }
+
+                feedBackProgress?.Invoke(100, 100);
+                feedBackMsg?.Invoke("椤圭洰瀵煎叆缁撴潫銆傘�傘��");*/
             return true;
 
-            #endregion 绗崄涓�姝� 椤圭洰鍙戝竷锛堣繘搴� 100%锛�
+            #endregion 寮冪敤  绗崄浜屾 椤圭洰鍙戝竷锛堣繘搴� 100%锛�
         }
     }
 }
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/03-MapLocation/SetXhsProjectMapLocationWizardPage.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/03-MapLocation/SetXhsProjectMapLocationWizardPage.cs
index c573304..99ea45b 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/03-MapLocation/SetXhsProjectMapLocationWizardPage.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/03-MapLocation/SetXhsProjectMapLocationWizardPage.cs
@@ -170,13 +170,13 @@
                             this.Invoke(new Action(() =>
                             {
                                 // 鏇存柊UI鎺т欢
-                                MessageBoxHelper.ShowError("瀵煎叆閿欒!");
+                                MessageBoxHelper.ShowSuccess("瀵煎叆鎴愬姛!");
                             }));
                         }
                         else
                         {
                             // 鐩存帴鏇存柊UI鎺т欢
-                            MessageBoxHelper.ShowError("瀵煎叆閿欒!");
+                            MessageBoxHelper.ShowSuccess("瀵煎叆鎴愬姛!");
                         }
                     }
                 }
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.Designer.cs
index 356e935..75f359f 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.Designer.cs
@@ -37,7 +37,6 @@
             stepItemForBimfaceUpload = new DevExpress.XtraEditors.StepProgressBarItem();
             stepItemForBimfaceRelation = new DevExpress.XtraEditors.StepProgressBarItem();
             stepItemForBimfaceTranslate = new DevExpress.XtraEditors.StepProgressBarItem();
-            stepItemForPublish = new DevExpress.XtraEditors.StepProgressBarItem();
             ((ISupportInitialize)stepProgressBar1).BeginInit();
             SuspendLayout();
             // 
@@ -52,10 +51,9 @@
             stepProgressBar1.Items.Add(stepItemForBimfaceUpload);
             stepProgressBar1.Items.Add(stepItemForBimfaceRelation);
             stepProgressBar1.Items.Add(stepItemForBimfaceTranslate);
-            stepProgressBar1.Items.Add(stepItemForPublish);
             stepProgressBar1.Location = new Point(0, 0);
             stepProgressBar1.Name = "stepProgressBar1";
-            stepProgressBar1.Orientation = Orientation.Vertical;
+            stepProgressBar1.SelectedItemIndex = 5;
             stepProgressBar1.ShadowDrawMode = DevExpress.XtraEditors.StepProgressBarShadowDrawMode.ActiveElements | DevExpress.XtraEditors.StepProgressBarShadowDrawMode.InactiveElements;
             stepProgressBar1.Size = new Size(941, 615);
             stepProgressBar1.TabIndex = 0;
@@ -68,6 +66,7 @@
             stepItemForHydro.Name = "stepItemForHydro";
             stepItemForHydro.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForHydro.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForHydro.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemForHydro.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemForProject
             // 
@@ -77,6 +76,7 @@
             stepItemForProject.Name = "stepItemForProject";
             stepItemForProject.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForProject.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForProject.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemForProject.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemForHydroRelation
             // 
@@ -86,6 +86,7 @@
             stepItemForHydroRelation.Name = "stepItemForHydroRelation";
             stepItemForHydroRelation.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForHydroRelation.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForHydroRelation.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemForHydroRelation.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemFormMap
             // 
@@ -95,6 +96,7 @@
             stepItemFormMap.Name = "stepItemFormMap";
             stepItemFormMap.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemFormMap.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemFormMap.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemFormMap.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemForBimfaceUpload
             // 
@@ -104,6 +106,7 @@
             stepItemForBimfaceUpload.Name = "stepItemForBimfaceUpload";
             stepItemForBimfaceUpload.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForBimfaceUpload.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForBimfaceUpload.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemForBimfaceUpload.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemForBimfaceRelation
             // 
@@ -113,6 +116,7 @@
             stepItemForBimfaceRelation.Name = "stepItemForBimfaceRelation";
             stepItemForBimfaceRelation.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForBimfaceRelation.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForBimfaceRelation.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
+            stepItemForBimfaceRelation.State = DevExpress.XtraEditors.StepProgressBarItemState.Active;
             // 
             // stepItemForBimfaceTranslate
             // 
@@ -122,15 +126,6 @@
             stepItemForBimfaceTranslate.Name = "stepItemForBimfaceTranslate";
             stepItemForBimfaceTranslate.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForBimfaceTranslate.Options.Indicator.ActiveStateImageOptions.SvgImage");
             stepItemForBimfaceTranslate.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
-            // 
-            // stepItemForPublish
-            // 
-            stepItemForPublish.ContentBlock1.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForPublish.ContentBlock1.ActiveStateImageOptions.SvgImage");
-            stepItemForPublish.ContentBlock1.InactiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForPublish.ContentBlock1.InactiveStateImageOptions.SvgImage");
-            stepItemForPublish.ContentBlock2.Caption = "椤圭洰鍙戝竷";
-            stepItemForPublish.Name = "stepItemForPublish";
-            stepItemForPublish.Options.Indicator.ActiveStateImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("stepItemForPublish.Options.Indicator.ActiveStateImageOptions.SvgImage");
-            stepItemForPublish.Options.Indicator.ActiveStateImageOptions.SvgImageSize = new Size(24, 24);
             // 
             // ImportXhsProjectCompletedCtrl
             // 
@@ -153,6 +148,5 @@
         private DevExpress.XtraEditors.StepProgressBarItem stepItemForBimfaceUpload;
         private DevExpress.XtraEditors.StepProgressBarItem stepItemForBimfaceRelation;
         private DevExpress.XtraEditors.StepProgressBarItem stepItemForBimfaceTranslate;
-        private DevExpress.XtraEditors.StepProgressBarItem stepItemForPublish;
     }
 }
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.cs
index 58db84c..4258b0d 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.cs
@@ -45,16 +45,11 @@
                                     this.stepItemForBimfaceTranslate.ContentBlock2.Description = "璺宠繃Bimface杞婚噺鍖栫瓑寰�...";
                                 }
                                 this.stepProgressBar1.SelectNext();
-                                if (vm.IsPublished)
-                                {
-                                    this.stepProgressBar1.SelectNext();
-                                }
                             }
                         }
                     }
                 }
             }
-
         }
 
         /// <summary>
@@ -70,7 +65,7 @@
         /// </summary>
         public bool AllowNext
         {
-            get { return false; }
+            get { return true; }
         }
 
         /// <summary>
@@ -86,7 +81,7 @@
         /// </summary>
         public bool AllowComplete
         {
-            get { return true; }
+            get { return false; }
         }
 
         /// <summary>
@@ -102,7 +97,7 @@
         /// </summary>
         public bool CanNext()
         {
-            return false;
+            return true;
         }
 
         /// <summary>
@@ -118,14 +113,8 @@
         /// </summary>
         public bool CanComplete()
         {
-            _vm.IsCompleted = true;
-            return true;
+            _vm.IsCompleted = false;
+            return false;
         }
-
-
-
-
-
-
     }
-}
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.resx b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.resx
index e92c7d7..9b42248 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.resx
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/05-ImportCompleted/ImportXhsProjectCompletedCtrl.resx
@@ -607,69 +607,4 @@
         ZWVuIiAvPg0KICA8L2c+DQo8L3N2Zz4L
 </value>
   </data>
-  <data name="stepItemForPublish.ContentBlock1.ActiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
-    <value>
-        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
-        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
-        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAKEDAAAC77u/
-        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
-        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
-        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
-        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
-        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkJsdWV7ZmlsbDojMTE3N0Q3O30KCS5Z
-        ZWxsb3d7ZmlsbDojRkZCMTE1O30KCS5CbGFja3tmaWxsOiM3MjcyNzI7fQoJLkdyZWVue2ZpbGw6IzAz
-        OUMyMzt9CgkuUmVke2ZpbGw6I0QxMUMxQzt9Cgkuc3Qwe29wYWNpdHk6MC43NTt9Cgkuc3Qxe29wYWNp
-        dHk6MC41O30KPC9zdHlsZT4NCiAgPGcgaWQ9IlVzZXIiPg0KICAgIDxwYXRoIGQ9Ik0xMCw5LjljLTAu
-        MSwwLjUsMC4yLDAuOSwwLjQsMS40YzAuMiwwLjUtMC4xLDEuNywwLjksMS42YzAsMCwwLDAuMSwwLDAu
-        MmMwLjYsMi4zLDIsNC45LDQuNyw0LjkgICBjMi43LDAsNC4yLTIuNiw0LjctNC45YzAsMCwwLTAuMSww
-        LTAuMWMxLDAuMSwwLjYtMS4xLDAuOS0xLjZjMC4yLTAuNSwwLjQtMC45LDAuMy0xLjRjLTAuMS0wLjQt
-        MC40LTAuNC0wLjUtMC4zICAgYzEuOC00LjktMS4xLTQuNy0xLjEtNC43UzIwLDIsMTQuOCwyQzEwLDIs
-        OS40LDYsMTAuNSw5LjZDMTAuNCw5LjYsMTAuMSw5LjcsMTAsOS45eiIgY2xhc3M9IkJsYWNrIiAvPg0K
-        ICAgIDxwYXRoIGQ9Ik0yMCwxOGMtMC44LDEuNS0yLjEsNC00LDRjLTEuOSwwLTMuMi0yLjUtNC00Yy0y
-        LjMsMy41LTgsMS04LDguNVYzMGgyNHYtMy41QzI4LDE5LjEsMjIuMywyMS40LDIwLDE4eiIgY2xhc3M9
-        IkJsYWNrIiAvPg0KICA8L2c+DQo8L3N2Zz4L
-</value>
-  </data>
-  <data name="stepItemForPublish.ContentBlock1.InactiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
-    <value>
-        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
-        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
-        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAKEDAAAC77u/
-        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
-        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
-        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
-        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
-        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkJsdWV7ZmlsbDojMTE3N0Q3O30KCS5Z
-        ZWxsb3d7ZmlsbDojRkZCMTE1O30KCS5CbGFja3tmaWxsOiM3MjcyNzI7fQoJLkdyZWVue2ZpbGw6IzAz
-        OUMyMzt9CgkuUmVke2ZpbGw6I0QxMUMxQzt9Cgkuc3Qwe29wYWNpdHk6MC43NTt9Cgkuc3Qxe29wYWNp
-        dHk6MC41O30KPC9zdHlsZT4NCiAgPGcgaWQ9IlVzZXIiPg0KICAgIDxwYXRoIGQ9Ik0xMCw5LjljLTAu
-        MSwwLjUsMC4yLDAuOSwwLjQsMS40YzAuMiwwLjUtMC4xLDEuNywwLjksMS42YzAsMCwwLDAuMSwwLDAu
-        MmMwLjYsMi4zLDIsNC45LDQuNyw0LjkgICBjMi43LDAsNC4yLTIuNiw0LjctNC45YzAsMCwwLTAuMSww
-        LTAuMWMxLDAuMSwwLjYtMS4xLDAuOS0xLjZjMC4yLTAuNSwwLjQtMC45LDAuMy0xLjRjLTAuMS0wLjQt
-        MC40LTAuNC0wLjUtMC4zICAgYzEuOC00LjktMS4xLTQuNy0xLjEtNC43UzIwLDIsMTQuOCwyQzEwLDIs
-        OS40LDYsMTAuNSw5LjZDMTAuNCw5LjYsMTAuMSw5LjcsMTAsOS45eiIgY2xhc3M9IkJsYWNrIiAvPg0K
-        ICAgIDxwYXRoIGQ9Ik0yMCwxOGMtMC44LDEuNS0yLjEsNC00LDRjLTEuOSwwLTMuMi0yLjUtNC00Yy0y
-        LjMsMy41LTgsMS04LDguNVYzMGgyNHYtMy41QzI4LDE5LjEsMjIuMywyMS40LDIwLDE4eiIgY2xhc3M9
-        IkJsYWNrIiAvPg0KICA8L2c+DQo8L3N2Zz4L
-</value>
-  </data>
-  <data name="stepItemForPublish.Options.Indicator.ActiveStateImageOptions.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
-    <value>
-        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
-        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
-        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAK4CAAAC77u/
-        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
-        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
-        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
-        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
-        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLlllbGxvd3tmaWxsOiNGRkIxMTU7fQoJ
-        LlJlZHtmaWxsOiNEMTFDMUM7fQoJLkJsdWV7ZmlsbDojMTE3N0Q3O30KCS5HcmVlbntmaWxsOiMwMzlD
-        MjM7fQoJLkJsYWNre2ZpbGw6IzcyNzI3Mjt9CgkuV2hpdGV7ZmlsbDojRkZGRkZGO30KCS5zdDB7b3Bh
-        Y2l0eTowLjU7fQoJLnN0MXtkaXNwbGF5Om5vbmU7fQoJLnN0MntkaXNwbGF5OmlubGluZTtmaWxsOiMw
-        MzlDMjM7fQoJLnN0M3tkaXNwbGF5OmlubGluZTtmaWxsOiNEMTFDMUM7fQoJLnN0NHtkaXNwbGF5Omlu
-        bGluZTtmaWxsOiM3MjcyNzI7fQo8L3N0eWxlPg0KICA8ZyBpZD0iTWFya0NvbXBsZXRlIj4NCiAgICA8
-        cG9seWdvbiBwb2ludHM9IjI3LDQgMTEsMjAgNSwxNCAyLDE3IDExLDI2IDMwLDcgICIgY2xhc3M9Ikdy
-        ZWVuIiAvPg0KICA8L2c+DQo8L3N2Zz4L
-</value>
-  </data>
 </root>
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.Designer.cs
new file mode 100644
index 0000000..84c438e
--- /dev/null
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.Designer.cs
@@ -0,0 +1,37 @@
+锘縩amespace HStation.WinFrmUI.Xhs
+{
+    partial class ProjectResultShowPanel
+    {
+        /// <summary> 
+        /// Required designer variable.
+        /// </summary>
+        private System.ComponentModel.IContainer components = null;
+
+        /// <summary> 
+        /// Clean up any resources being used.
+        /// </summary>
+        /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
+        protected override void Dispose(bool disposing)
+        {
+            if (disposing && (components != null))
+            {
+                components.Dispose();
+            }
+            base.Dispose(disposing);
+        }
+
+        #region Component Designer generated code
+
+        /// <summary> 
+        /// Required method for Designer support - do not modify 
+        /// the contents of this method with the code editor.
+        /// </summary>
+        private void InitializeComponent()
+        {
+            components = new System.ComponentModel.Container();
+            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
+        }
+
+        #endregion
+    }
+}
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.cs
new file mode 100644
index 0000000..4ce7354
--- /dev/null
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.cs
@@ -0,0 +1,87 @@
+锘縩amespace HStation.WinFrmUI.Xhs
+{
+    public partial class ProjectResultShowPanel : DevExpress.XtraEditors.XtraUserControl, IWizardPage<ImportXhsProjectViewModel>
+    {
+        public ProjectResultShowPanel()
+        {
+            InitializeComponent();
+        }
+
+        /// <summary>
+        /// 椤甸潰鐘舵�佹敼鍙樹簨浠�
+        /// </summary>
+        public event Action PageStateChangedEvent;
+
+        private ImportXhsProjectViewModel _vm = null;//鎿嶄綔瀵硅薄
+
+        /// <summary>
+        /// 鍏佽涓婁竴姝�
+        /// </summary>
+        public bool AllowPrev
+        {
+            get { return false; }
+        }
+
+        /// <summary>
+        /// 鍏佽涓嬩竴姝�
+        /// </summary>
+        public bool AllowNext
+        {
+            get { return false; }
+        }
+
+        /// <summary>
+        /// 鍏佽鍙栨秷
+        /// </summary>
+        public bool AllowCancel
+        {
+            get { return false; }
+        }
+
+        /// <summary>
+        /// 鍏佽瀹屾垚
+        /// </summary>
+        public bool AllowComplete
+        {
+            get { return true; }
+        }
+
+        /// <summary>
+        /// 鑳藉惁涓婁竴姝�
+        /// </summary>
+        public bool CanPrev()
+        {
+            return false;
+        }
+
+        /// <summary>
+        /// 鑳藉惁涓嬩竴姝�
+        /// </summary>
+        public bool CanNext()
+        {
+            return false;
+        }
+
+        /// <summary>
+        /// 鑳藉惁鍙栨秷
+        /// </summary>
+        public bool CanCancel()
+        {
+            return false;
+        }
+
+        /// <summary>
+        /// 鑳藉惁瀹屾垚
+        /// </summary>
+        public bool CanComplete()
+        {
+            _vm.IsCompleted = true;
+            return true;
+        }
+
+        public void InitialPage(ImportXhsProjectViewModel t)
+        {
+            _vm = t;
+        }
+    }
+}
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.resx b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.resx
new file mode 100644
index 0000000..1af7de1
--- /dev/null
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/01-import/06-ProjectResultShowPanel/ProjectResultShowPanel.resx
@@ -0,0 +1,120 @@
+锘�<?xml version="1.0" encoding="utf-8"?>
+<root>
+  <!-- 
+    Microsoft ResX Schema 
+    
+    Version 2.0
+    
+    The primary goals of this format is to allow a simple XML format 
+    that is mostly human readable. The generation and parsing of the 
+    various data types are done through the TypeConverter classes 
+    associated with the data types.
+    
+    Example:
+    
+    ... ado.net/XML headers & schema ...
+    <resheader name="resmimetype">text/microsoft-resx</resheader>
+    <resheader name="version">2.0</resheader>
+    <resheader name="reader">System.Resources.ResXResourceReader, System.Windows.Forms, ...</resheader>
+    <resheader name="writer">System.Resources.ResXResourceWriter, System.Windows.Forms, ...</resheader>
+    <data name="Name1"><value>this is my long string</value><comment>this is a comment</comment></data>
+    <data name="Color1" type="System.Drawing.Color, System.Drawing">Blue</data>
+    <data name="Bitmap1" mimetype="application/x-microsoft.net.object.binary.base64">
+        <value>[base64 mime encoded serialized .NET Framework object]</value>
+    </data>
+    <data name="Icon1" type="System.Drawing.Icon, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
+        <value>[base64 mime encoded string representing a byte array form of the .NET Framework object]</value>
+        <comment>This is a comment</comment>
+    </data>
+                
+    There are any number of "resheader" rows that contain simple 
+    name/value pairs.
+    
+    Each data row contains a name, and value. The row also contains a 
+    type or mimetype. Type corresponds to a .NET class that support 
+    text/value conversion through the TypeConverter architecture. 
+    Classes that don't support this are serialized and stored with the 
+    mimetype set.
+    
+    The mimetype is used for serialized objects, and tells the 
+    ResXResourceReader how to depersist the object. This is currently not 
+    extensible. For a given mimetype the value must be set accordingly:
+    
+    Note - application/x-microsoft.net.object.binary.base64 is the format 
+    that the ResXResourceWriter will generate, however the reader can 
+    read any of the formats listed below.
+    
+    mimetype: application/x-microsoft.net.object.binary.base64
+    value   : The object must be serialized with 
+            : System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
+            : and then encoded with base64 encoding.
+    
+    mimetype: application/x-microsoft.net.object.soap.base64
+    value   : The object must be serialized with 
+            : System.Runtime.Serialization.Formatters.Soap.SoapFormatter
+            : and then encoded with base64 encoding.
+
+    mimetype: application/x-microsoft.net.object.bytearray.base64
+    value   : The object must be serialized into a byte array 
+            : using a System.ComponentModel.TypeConverter
+            : and then encoded with base64 encoding.
+    -->
+  <xsd:schema id="root" xmlns="" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
+    <xsd:import namespace="http://www.w3.org/XML/1998/namespace" />
+    <xsd:element name="root" msdata:IsDataSet="true">
+      <xsd:complexType>
+        <xsd:choice maxOccurs="unbounded">
+          <xsd:element name="metadata">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" />
+              </xsd:sequence>
+              <xsd:attribute name="name" use="required" type="xsd:string" />
+              <xsd:attribute name="type" type="xsd:string" />
+              <xsd:attribute name="mimetype" type="xsd:string" />
+              <xsd:attribute ref="xml:space" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="assembly">
+            <xsd:complexType>
+              <xsd:attribute name="alias" type="xsd:string" />
+              <xsd:attribute name="name" type="xsd:string" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="data">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+                <xsd:element name="comment" type="xsd:string" minOccurs="0" msdata:Ordinal="2" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" use="required" msdata:Ordinal="1" />
+              <xsd:attribute name="type" type="xsd:string" msdata:Ordinal="3" />
+              <xsd:attribute name="mimetype" type="xsd:string" msdata:Ordinal="4" />
+              <xsd:attribute ref="xml:space" />
+            </xsd:complexType>
+          </xsd:element>
+          <xsd:element name="resheader">
+            <xsd:complexType>
+              <xsd:sequence>
+                <xsd:element name="value" type="xsd:string" minOccurs="0" msdata:Ordinal="1" />
+              </xsd:sequence>
+              <xsd:attribute name="name" type="xsd:string" use="required" />
+            </xsd:complexType>
+          </xsd:element>
+        </xsd:choice>
+      </xsd:complexType>
+    </xsd:element>
+  </xsd:schema>
+  <resheader name="resmimetype">
+    <value>text/microsoft-resx</value>
+  </resheader>
+  <resheader name="version">
+    <value>2.0</value>
+  </resheader>
+  <resheader name="reader">
+    <value>System.Resources.ResXResourceReader, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+  <resheader name="writer">
+    <value>System.Resources.ResXResourceWriter, System.Windows.Forms, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
+  </resheader>
+</root>
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.Designer.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.Designer.cs
index 98749ce..43df956 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.Designer.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.Designer.cs
@@ -30,6 +30,11 @@
         {
             components = new Container();
             ComponentResourceManager resources = new ComponentResourceManager(typeof(XhsProjectMgrPage));
+            DevExpress.XtraEditors.Controls.EditorButtonImageOptions editorButtonImageOptions1 = new DevExpress.XtraEditors.Controls.EditorButtonImageOptions();
+            DevExpress.Utils.SerializableAppearanceObject serializableAppearanceObject1 = new DevExpress.Utils.SerializableAppearanceObject();
+            DevExpress.Utils.SerializableAppearanceObject serializableAppearanceObject2 = new DevExpress.Utils.SerializableAppearanceObject();
+            DevExpress.Utils.SerializableAppearanceObject serializableAppearanceObject3 = new DevExpress.Utils.SerializableAppearanceObject();
+            DevExpress.Utils.SerializableAppearanceObject serializableAppearanceObject4 = new DevExpress.Utils.SerializableAppearanceObject();
             ribbonControl1 = new DevExpress.XtraBars.Ribbon.RibbonControl();
             barBtnAdd = new DevExpress.XtraBars.BarButtonItem();
             barBtnEdit = new DevExpress.XtraBars.BarButtonItem();
@@ -55,17 +60,20 @@
             colName = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colStartTime = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colEndTime = new DevExpress.XtraTreeList.Columns.TreeListColumn();
-            colPublishStatus = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colAddress = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colCustomer = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colFlags = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colTagName = new DevExpress.XtraTreeList.Columns.TreeListColumn();
             colDescription = new DevExpress.XtraTreeList.Columns.TreeListColumn();
+            ColModelState = new DevExpress.XtraTreeList.Columns.TreeListColumn();
+            ColViewBimface = new DevExpress.XtraTreeList.Columns.TreeListColumn();
+            repositoryItemButtonEdit1 = new DevExpress.XtraEditors.Repository.RepositoryItemButtonEdit();
             xhsProjectMgrViewModelBindingSource = new BindingSource(components);
             panelControl1 = new DevExpress.XtraEditors.PanelControl();
             svgImg32 = new DevExpress.Utils.SvgImageCollection(components);
             ((ISupportInitialize)ribbonControl1).BeginInit();
             ((ISupportInitialize)treeList1).BeginInit();
+            ((ISupportInitialize)repositoryItemButtonEdit1).BeginInit();
             ((ISupportInitialize)xhsProjectMgrViewModelBindingSource).BeginInit();
             ((ISupportInitialize)panelControl1).BeginInit();
             panelControl1.SuspendLayout();
@@ -143,7 +151,6 @@
             barBtnPublish.Id = 7;
             barBtnPublish.ImageOptions.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("barBtnPublish.ImageOptions.SvgImage");
             barBtnPublish.Name = "barBtnPublish";
-            barBtnPublish.ItemClick += barBtnPublish_ItemClick;
             // 
             // barBtnDeprecated
             // 
@@ -213,6 +220,7 @@
             ribPageGroupForOperation.ItemLinks.Add(barBtnDeprecated);
             ribPageGroupForOperation.Name = "ribPageGroupForOperation";
             ribPageGroupForOperation.Text = "鎿嶄綔";
+            ribPageGroupForOperation.Visible = false;
             // 
             // ribPageGroupForHydro
             // 
@@ -238,18 +246,28 @@
             // 
             // treeList1
             // 
+            treeList1.Appearance.HeaderPanel.Options.UseTextOptions = true;
+            treeList1.Appearance.HeaderPanel.TextOptions.HAlignment = DevExpress.Utils.HorzAlignment.Center;
             treeList1.BorderStyle = DevExpress.XtraEditors.Controls.BorderStyles.NoBorder;
-            treeList1.Columns.AddRange(new DevExpress.XtraTreeList.Columns.TreeListColumn[] { colNO, colName, colStartTime, colEndTime, colPublishStatus, colAddress, colCustomer, colFlags, colTagName, colDescription });
+            treeList1.Columns.AddRange(new DevExpress.XtraTreeList.Columns.TreeListColumn[] { colNO, colName, colStartTime, colEndTime, colAddress, colCustomer, colFlags, colTagName, colDescription, ColModelState, ColViewBimface });
             treeList1.DataSource = xhsProjectMgrViewModelBindingSource;
             treeList1.Dock = DockStyle.Fill;
             treeList1.Location = new Point(0, 1);
             treeList1.MenuManager = ribbonControl1;
             treeList1.Name = "treeList1";
+            treeList1.OptionsBehavior.PopulateServiceColumns = true;
+            treeList1.RepositoryItems.AddRange(new DevExpress.XtraEditors.Repository.RepositoryItem[] { repositoryItemButtonEdit1 });
             treeList1.Size = new Size(998, 568);
             treeList1.TabIndex = 1;
+            treeList1.RowCellClick += treeList1_RowCellClick;
+            treeList1.CustomDrawRow += treeList1_CustomDrawRow;
             // 
             // colNO
             // 
+            colNO.AppearanceCell.Options.UseTextOptions = true;
+            colNO.AppearanceCell.TextOptions.HAlignment = DevExpress.Utils.HorzAlignment.Center;
+            colNO.AppearanceHeader.Options.UseTextOptions = true;
+            colNO.AppearanceHeader.TextOptions.HAlignment = DevExpress.Utils.HorzAlignment.Center;
             colNO.FieldName = "NO";
             colNO.Name = "colNO";
             colNO.Visible = true;
@@ -276,40 +294,33 @@
             colEndTime.Visible = true;
             colEndTime.VisibleIndex = 3;
             // 
-            // colPublishStatus
-            // 
-            colPublishStatus.FieldName = "PublishStatus";
-            colPublishStatus.Name = "colPublishStatus";
-            colPublishStatus.Visible = true;
-            colPublishStatus.VisibleIndex = 4;
-            // 
             // colAddress
             // 
             colAddress.FieldName = "Address";
             colAddress.Name = "colAddress";
             colAddress.Visible = true;
-            colAddress.VisibleIndex = 5;
+            colAddress.VisibleIndex = 4;
             // 
             // colCustomer
             // 
             colCustomer.FieldName = "Customer";
             colCustomer.Name = "colCustomer";
             colCustomer.Visible = true;
-            colCustomer.VisibleIndex = 6;
+            colCustomer.VisibleIndex = 5;
             // 
             // colFlags
             // 
             colFlags.FieldName = "Flags";
             colFlags.Name = "colFlags";
             colFlags.Visible = true;
-            colFlags.VisibleIndex = 7;
+            colFlags.VisibleIndex = 6;
             // 
             // colTagName
             // 
             colTagName.FieldName = "TagName";
             colTagName.Name = "colTagName";
             colTagName.Visible = true;
-            colTagName.VisibleIndex = 8;
+            colTagName.VisibleIndex = 7;
             // 
             // colDescription
             // 
@@ -317,6 +328,31 @@
             colDescription.Name = "colDescription";
             colDescription.Visible = true;
             colDescription.VisibleIndex = 9;
+            // 
+            // ColModelState
+            // 
+            ColModelState.Caption = "妯″瀷鐘舵��";
+            ColModelState.Name = "ColModelState";
+            ColModelState.Visible = true;
+            ColModelState.VisibleIndex = 8;
+            // 
+            // ColViewBimface
+            // 
+            ColViewBimface.Caption = "鏌ョ湅涓夌淮妯″瀷";
+            ColViewBimface.ColumnEdit = repositoryItemButtonEdit1;
+            ColViewBimface.Name = "ColViewBimface";
+            ColViewBimface.OptionsColumn.AllowEdit = false;
+            ColViewBimface.Visible = true;
+            ColViewBimface.VisibleIndex = 10;
+            // 
+            // repositoryItemButtonEdit1
+            // 
+            repositoryItemButtonEdit1.AutoHeight = false;
+            editorButtonImageOptions1.SvgImage = (DevExpress.Utils.Svg.SvgImage)resources.GetObject("editorButtonImageOptions1.SvgImage");
+            editorButtonImageOptions1.SvgImageSize = new Size(25, 25);
+            repositoryItemButtonEdit1.Buttons.AddRange(new DevExpress.XtraEditors.Controls.EditorButton[] { new DevExpress.XtraEditors.Controls.EditorButton(DevExpress.XtraEditors.Controls.ButtonPredefines.Glyph, "", -1, true, true, false, editorButtonImageOptions1, new DevExpress.Utils.KeyShortcut(Keys.None), serializableAppearanceObject1, serializableAppearanceObject2, serializableAppearanceObject3, serializableAppearanceObject4, "", null, null, DevExpress.Utils.ToolTipAnchor.Default) });
+            repositoryItemButtonEdit1.Name = "repositoryItemButtonEdit1";
+            repositoryItemButtonEdit1.TextEditStyle = DevExpress.XtraEditors.Controls.TextEditStyles.HideTextEditor;
             // 
             // xhsProjectMgrViewModelBindingSource
             // 
@@ -350,6 +386,7 @@
             Size = new Size(998, 670);
             ((ISupportInitialize)ribbonControl1).EndInit();
             ((ISupportInitialize)treeList1).EndInit();
+            ((ISupportInitialize)repositoryItemButtonEdit1).EndInit();
             ((ISupportInitialize)xhsProjectMgrViewModelBindingSource).EndInit();
             ((ISupportInitialize)panelControl1).EndInit();
             panelControl1.ResumeLayout(false);
@@ -376,7 +413,6 @@
         private DevExpress.XtraTreeList.Columns.TreeListColumn colName;
         private DevExpress.XtraTreeList.Columns.TreeListColumn colStartTime;
         private DevExpress.XtraTreeList.Columns.TreeListColumn colEndTime;
-        private DevExpress.XtraTreeList.Columns.TreeListColumn colPublishStatus;
         private DevExpress.XtraTreeList.Columns.TreeListColumn colAddress;
         private DevExpress.XtraTreeList.Columns.TreeListColumn colCustomer;
         private DevExpress.XtraTreeList.Columns.TreeListColumn colFlags;
@@ -394,5 +430,8 @@
         private DevExpress.XtraBars.BarButtonItem barBtnRefresh;
         private DevExpress.XtraEditors.PanelControl panelControl1;
         private DevExpress.Utils.SvgImageCollection svgImg32;
+        private DevExpress.XtraTreeList.Columns.TreeListColumn ColModelState;
+        private DevExpress.XtraTreeList.Columns.TreeListColumn ColViewBimface;
+        private DevExpress.XtraEditors.Repository.RepositoryItemButtonEdit repositoryItemButtonEdit1;
     }
 }
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.cs
index af6bae1..7099e1d 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.cs
@@ -1,6 +1,8 @@
 锘縰sing DevExpress.CodeParser;
 using DevExpress.Utils;
+using DevExpress.XtraTreeList;
 using HStation.WinFrmUI.Xhs;
+using System.Data;
 
 namespace HStation.WinFrmUI
 {
@@ -25,6 +27,11 @@
         public override async void InitialDataSource()
         {
             base.InitialDataSource();
+            this.SetBindingData();
+        }
+
+        private async void SetBindingData()
+        {
             _bll = new BLL.XhsProjectExtensions();
             var allProjectList = await _bll.GetAll();
             _allProjectList = new List<XhsProjectMgrViewModel>();
@@ -32,16 +39,41 @@
             {
                 foreach (var project in allProjectList)
                 {
-                    var vm = new XhsProjectMgrViewModel(project);
-                    _allProjectList.Add(vm);
+                    if (await IsHaveBimFace(project.ID))
+                    {
+                        var vm = new XhsProjectMgrViewModel(project, true);
+                        _allProjectList.Add(vm);
+                    }
+                    else
+                    {
+                        var vm = new XhsProjectMgrViewModel(project, false);
+                        _allProjectList.Add(vm);
+                    }
                 }
             }
             this.xhsProjectMgrViewModelBindingSource.DataSource = _allProjectList;
         }
 
-        //鍙戝竷
-        private void barBtnPublish_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
+        //鏌ユ壘椤圭洰鏄惁瀛樺湪妯″瀷
+        private async Task<bool> IsHaveBimFace(long ProjectID)
         {
+            var projectSite = await new BLL.XhsProjectSiteStd().GetDefaultByProjectID(ProjectID);
+            if (projectSite == null)
+            {
+                return false;
+            }
+            var relation = await new Yw.BLL.BimfaceFileRelationStd()
+               .GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, projectSite.ID, Yw.Bimface.Purpose.Simulation);
+            if (relation == null)
+            {
+                return false;
+            }
+            var bimfaceFile = await new Yw.BLL.BimfaceFileStd().GetByID(relation.BimfaceFileID);
+            if (bimfaceFile == null)
+            {
+                return false;
+            }
+            return true;
         }
 
         //鏌ョ湅bimface妯″瀷
@@ -97,7 +129,7 @@
         //鍒锋柊
         private void barBtnRefresh_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
         {
-            this.RefreshData();
+            this.SetBindingData();
         }
 
         #region 褰撳墠
@@ -140,7 +172,7 @@
                 {
                     rhs.ID = id;
                     var vmo = await _bll.GetByID(id);
-                    _allProjectList.Add(new XhsProjectMgrViewModel(vmo));
+                    _allProjectList.Add(new XhsProjectMgrViewModel(vmo, false));
                     this.xhsProjectMgrViewModelBindingSource.ResetBindings(false);
                     if (mapinfo != null)
                     {
@@ -219,5 +251,42 @@
         }
 
         #endregion 鍩虹鎿嶄綔
+
+        private void treeList1_CustomDrawRow(object sender, DevExpress.XtraTreeList.CustomDrawRowEventArgs e)
+        {
+            var a = repositoryItemButtonEdit1.ReadOnly = true;
+        }
+
+        private async void treeList1_RowCellClick(object sender, RowCellClickEventArgs e)
+        {
+            if (_allProjectList == null || _allProjectList.Count < 1)
+                return;
+            var vm = GetCurrentViewModel();
+            if (vm == null)
+            {
+                return;
+            }
+            if (e.Column != this.ColViewBimface)
+                return;
+            if (!vm.IsHaveBimface)
+            {
+                TipFormHelper.ShowWarn("璇峰厛涓婁紶鏂囦欢鍐嶈繘琛屾搷浣�!");
+                return;
+            }
+            var guid = new PageGuid()
+            {
+                Modular = Yw.WinFrmUI.PageModular.Bimface,
+                MoudingType = Yw.WinFrmUI.Page.eMoudingType.Tab,
+                Function = Yw.WinFrmUI.PageFunction.ViewBimface3d,
+                TagName = $"{vm.ID}"
+            };
+
+            if (!IsExistPage(guid, true))
+            {
+                var page = new ViewXhsProjectBimfacePage();
+                await page.SetBindingData(vm.ID);
+                CreatePage(page, guid);
+            }
+        }
     }
 }
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.resx b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.resx
index a9a45d6..197d058 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.resx
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrPage.resx
@@ -388,6 +388,30 @@
         Zz4L
 </value>
   </data>
+  <data name="editorButtonImageOptions1.SvgImage" type="DevExpress.Utils.Svg.SvgImage, DevExpress.Data.v23.2" mimetype="application/x-microsoft.net.object.bytearray.base64">
+    <value>
+        AAEAAAD/////AQAAAAAAAAAMAgAAAFlEZXZFeHByZXNzLkRhdGEudjIzLjIsIFZlcnNpb249MjMuMi40
+        LjAsIEN1bHR1cmU9bmV1dHJhbCwgUHVibGljS2V5VG9rZW49Yjg4ZDE3NTRkNzAwZTQ5YQUBAAAAHURl
+        dkV4cHJlc3MuVXRpbHMuU3ZnLlN2Z0ltYWdlAQAAAAREYXRhBwICAAAACQMAAAAPAwAAAPADAAAC77u/
+        PD94bWwgdmVyc2lvbj0nMS4wJyBlbmNvZGluZz0nVVRGLTgnPz4NCjxzdmcgeD0iMHB4IiB5PSIwcHgi
+        IHZpZXdCb3g9IjAgMCAzMiAzMiIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcv
+        MjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3Bh
+        Y2U9InByZXNlcnZlIiBpZD0iTGF5ZXJfMSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAg
+        MzIgMzIiPg0KICA8c3R5bGUgdHlwZT0idGV4dC9jc3MiPgoJLkJsYWNre2ZpbGw6IzcyNzI3Mjt9Cgku
+        WWVsbG93e2ZpbGw6I0ZGQjExNTt9CgkuQmx1ZXtmaWxsOiMxMTc3RDc7fQoJLlJlZHtmaWxsOiNEMTFD
+        MUM7fQoJLldoaXRle2ZpbGw6I0ZGRkZGRjt9CgkuR3JlZW57ZmlsbDojMDM5QzIzO30KCS5zdDB7Zmls
+        bDojNzI3MjcyO30KCS5zdDF7b3BhY2l0eTowLjU7fQoJLnN0MntvcGFjaXR5OjAuNzU7fQo8L3N0eWxl
+        Pg0KICA8ZyBpZD0iQiI+DQogICAgPHBhdGggZD0iTTE2LjQsMTMuN2gtMS4zdi0zLjRoMS4xYzEuNCww
+        LDIuMSwwLjUsMi4xLDEuNmMwLDAuNS0wLjIsMC45LTAuNSwxLjNDMTcuNCwxMy41LDE2LjksMTMuNywx
+        Ni40LDEzLjd6ICAgIE0xNi43LDE2aC0xLjZ2My43aDEuNmMwLjcsMCwxLjItMC4yLDEuNS0wLjVjMC40
+        LTAuMywwLjUtMC44LDAuNS0xLjRjMC0wLjYtMC4yLTEtMC42LTEuM0MxNy44LDE2LjEsMTcuMywxNiwx
+        Ni43LDE2eiBNMzAsMTYgICBjMCw3LjctNi4zLDE0LTE0LDE0UzIsMjMuNywyLDE2UzguMywyLDE2LDJT
+        MzAsOC4zLDMwLDE2eiBNMjIsMTcuOGMwLTAuOC0wLjMtMS42LTAuOS0yLjJzLTEuMy0xLTIuMi0xLjF2
+        MCAgIGMwLjgtMC4yLDEuNC0wLjYsMS45LTEuMWMwLjUtMC42LDAuNy0xLjIsMC43LTJDMjEuNSw5LjEs
+        MjAsOCwxNi45LDhIMTJ2MTRoNS4yYzEuNSwwLDIuNy0wLjQsMy42LTEuMUMyMS42LDIwLjEsMjIsMTku
+        MSwyMiwxNy44eiAgICIgY2xhc3M9IlJlZCIgLz4NCiAgPC9nPg0KPC9zdmc+Cw==
+</value>
+  </data>
   <metadata name="xhsProjectMgrViewModelBindingSource.TrayLocation" type="System.Drawing.Point, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a">
     <value>17, 17</value>
   </metadata>
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrViewModel.cs b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrViewModel.cs
index 24adeb0..d6d40ab 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrViewModel.cs
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/02-project/03-mgr/XhsProjectMgrViewModel.cs
@@ -17,7 +17,7 @@
         /// <summary>
         ///
         /// </summary>
-        public XhsProjectMgrViewModel(Vmo.Xhs.XhsProjectExtensions project)
+        public XhsProjectMgrViewModel(Vmo.Xhs.XhsProjectExtensions project, bool IsHaveBimface)
         {
             this.ID = project.ID;
             this.ParentID = project.ParentID;
@@ -29,15 +29,16 @@
             this.TagName = project.TagName;
             this.SortCode = project.SortCode;
             this.Description = project.Description;
+            this.IsHaveBimface = IsHaveBimface;
         }
 
-        /// <summary>
-        ///
-        /// </summary>
-        public XhsProjectMgrViewModel(Vmo.Xhs.XhsProjectExtensions project, bool hasLocation) : this(project)
-        {
-            this.HasLocation = hasLocation;
-        }
+        /*        /// <summary>
+                ///
+                /// </summary>
+                public XhsProjectMgrViewModel(Vmo.Xhs.XhsProjectExtensions project, bool hasLocation) : this(project)
+                {
+                    this.HasLocation = hasLocation;
+                }*/
 
         public void Reset(Vmo.Xhs.XhsProjectExtensions project)
         {
@@ -137,10 +138,15 @@
         [Display(Name = "璇存槑")]
         public string Description { get; set; }
 
+        /*      /// <summary>
+              /// 瀹氫綅
+              /// </summary>
+              [Display(Name = "瀹氫綅")]
+              public bool HasLocation { get; set; }*/
+
         /// <summary>
-        /// 瀹氫綅
+        /// 鏄惁瀛樺湪涓夌淮妯″瀷
         /// </summary>
-        [Display(Name = "瀹氫綅")]
-        public bool HasLocation { get; set; }
+        public bool IsHaveBimface { get; set; }
     }
 }
\ No newline at end of file
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj
index a36d727..69041c2 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj
@@ -53,12 +53,13 @@
   <ItemGroup>
     <Folder Include="map\gaode\css\" />
     <Folder Include="00-core\" />
+    <Folder Include="Resources\" />
   </ItemGroup>
 
   <ItemGroup>
-    <ProjectReference Include="..\..\BLL\HStation.BLL.Assets.Core\HStation.BLL.Assets.Core.csproj" />
     <ProjectReference Include="..\..\BLL\HStation.BLL.Xhs.Core\HStation.BLL.Xhs.Core.csproj" />
     <ProjectReference Include="..\..\Hydro\HStation.Hydro.Core\HStation.Hydro.Core.csproj" />
+    <ProjectReference Include="..\HStation.WinFrmUI.Assets.Core\HStation.WinFrmUI.Assets.Core.csproj" />
     <ProjectReference Include="..\HStation.WinFrmUI.Bimface.Core\HStation.WinFrmUI.Bimface.Core.csproj" />
     <ProjectReference Include="..\Hstation.WinFrmUI.Core\HStation.WinFrmUI.Core.csproj" />
     <ProjectReference Include="..\HStation.WinFrmUI.Hydro.Core\HStation.WinFrmUI.Hydro.Core.csproj" />
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj.user b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj.user
index 5414610..a9ab4f1 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj.user
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/HStation.WinFrmUI.Xhs.Core.csproj.user
@@ -34,6 +34,9 @@
     <Compile Update="02-project\01-import\05-ImportCompleted\ImportXhsProjectCompletedCtrl.cs">
       <SubType>UserControl</SubType>
     </Compile>
+    <Compile Update="02-project\01-import\06-ProjectResultShowPanel\ProjectResultShowPanel.cs">
+      <SubType>UserControl</SubType>
+    </Compile>
     <Compile Update="02-project\02-bimface\ViewXhsProjectBimfacePage.cs">
       <SubType>UserControl</SubType>
     </Compile>
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/img/xhs_project.png b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/img/xhs_project.png
index 39d9f02..d5c3f0e 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/img/xhs_project.png
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/img/xhs_project.png
Binary files differ
diff --git a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/js/xhs_base64.js b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/js/xhs_base64.js
index 9c53101..1999cc7 100644
--- a/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/js/xhs_base64.js
+++ b/WinFrmUI/HStation.WinFrmUI.Xhs.Core/map/gaode/js/xhs_base64.js
@@ -1,4 +1,4 @@
 锘�//鍥剧墖
 var xhs_image_base64 = {
-    project: ''
+    project: ''
 };
\ No newline at end of file
diff --git a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/ImageLib.cs b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/ImageLib.cs
index 8cecf58..e92ad06 100644
--- a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/ImageLib.cs
+++ b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/ImageLib.cs
@@ -10,47 +10,57 @@
     public class ImageLib
     {
         #region 16
-        public static ImageCollection Lib16
+
+        public static ImageCollection Lib
         {
             get
             {
-                if (_lib16 == null)
+                if (_lib == null)
                 {
-                    _lib16 = new ImageCollection();
-                    _lib16.ImageSize = new Size(16, 16);
-                    _lib16.Images.Add(Resource1.Group, "Group");
-                    _lib16.Images.Add(Resource1.Series, "Series");
-                    _lib16.Images.Add(Resource1.Question, "Question");
+                    _lib = new ImageCollection();
+                    _lib.ImageSize = new Size(16, 16);
+                    _lib.Images.Add(Resource1.Group, "Group");
+                    _lib.Images.Add(Resource1.Series, "Series");
+                    _lib.Images.Add(Resource1.Question, "Question");
+                    _lib.Images.Add(Resource1.NotImported, "NotImported");
                 }
-                return _lib16;
+                return _lib;
             }
         }
 
-        private static ImageCollection _lib16;
+        private static ImageCollection _lib;
 
-        public static int Group16
+        public static int Group
         {
             get => GetImage16Index("Group");
         }
-        public static int Series16
+
+        public static int Series
         {
             get => GetImage16Index("Series");
         }
-        public static int Question16
+
+        public static int Question
         {
             get => GetImage16Index("Question");
         }
-        private static int GetImage16Index(string imgName)
-        {
-            var img = Lib16.Images[imgName];
-            if (img == null)
-                img = Lib16.Images["Question"];
 
-            return _lib16.Images.IndexOf(img);
+        public static int NotImported
+        {
+            get => GetImage16Index("NotImported");
         }
 
-        #endregion
-        
+        private static int GetImage16Index(string imgName)
+        {
+            var img = Lib.Images[imgName];
+            if (img == null)
+                img = Lib.Images["Question"];
+
+            return _lib.Images.IndexOf(img);
+        }
+
+        #endregion 16
+
         #region Svg
 
         public static SvgImageCollection LibSvg
@@ -86,7 +96,6 @@
             get => LibSvg[2];
         }
 
-        #endregion
-
+        #endregion Svg
     }
 }
\ No newline at end of file
diff --git a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.Designer.cs b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.Designer.cs
index 5b33142..d73bbda 100644
--- a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.Designer.cs
+++ b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.Designer.cs
@@ -71,6 +71,16 @@
         }
         
         /// <summary>
+        ///   鏌ユ壘 System.Drawing.Bitmap 绫诲瀷鐨勬湰鍦板寲璧勬簮銆�
+        /// </summary>
+        internal static System.Drawing.Bitmap NotImported {
+            get {
+                object obj = ResourceManager.GetObject("NotImported", resourceCulture);
+                return ((System.Drawing.Bitmap)(obj));
+            }
+        }
+        
+        /// <summary>
         ///   鏌ユ壘 System.Byte[] 绫诲瀷鐨勬湰鍦板寲璧勬簮銆�
         /// </summary>
         internal static byte[] Project {
diff --git a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.resx b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.resx
index 770226e..9475450 100644
--- a/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.resx
+++ b/WinFrmUI/Hstation.WinFrmUI.Core/Lib/Resource1.resx
@@ -121,6 +121,9 @@
   <data name="Group" type="System.Resources.ResXFileRef, System.Windows.Forms">
     <value>..\Resources\Group.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value>
   </data>
+  <data name="NotImported" type="System.Resources.ResXFileRef, System.Windows.Forms">
+    <value>..\Resources\鏈鍏ユ彁绀�.png;System.Drawing.Bitmap, System.Drawing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a</value>
+  </data>
   <data name="Project" type="System.Resources.ResXFileRef, System.Windows.Forms">
     <value>..\Resources\Project.svg;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
   </data>

--
Gitblit v1.9.3