From 34ee2c9c1e7287ca1002ede66a70bdbf9268cd27 Mon Sep 17 00:00:00 2001
From: wells.liu <wells.liu@broconcentric.com>
Date: 星期四, 02 七月 2020 18:22:46 +0800
Subject: [PATCH] 合并

---
 src/Bro.Common.Model/Helper/PropertyConvertHelper.cs |   45 +++++++++++++++++++++++++++++++++------------
 1 files changed, 33 insertions(+), 12 deletions(-)

diff --git a/src/Bro.Common.Model/Helper/PropertyConvertHelper.cs b/src/Bro.Common.Model/Helper/PropertyConvertHelper.cs
index 1f56ef7..dd48235 100644
--- a/src/Bro.Common.Model/Helper/PropertyConvertHelper.cs
+++ b/src/Bro.Common.Model/Helper/PropertyConvertHelper.cs
@@ -1,5 +1,7 @@
-锘縰sing Bro.Common.Factory;
+锘縰sing Autofac;
+using Bro.Common.Factory;
 using Bro.Common.Interface;
+using Bro.Common.Model;
 using Newtonsoft.Json;
 using System;
 using System.Collections;
@@ -112,7 +114,7 @@
         //    set => hash = value;
         //}
 
-        public abstract Hashtable GetConvertHash();
+        public abstract Hashtable GetConvertHash(ITypeDescriptorContext context);
 
         public override bool GetStandardValuesSupported(ITypeDescriptorContext context)
         {
@@ -121,7 +123,7 @@
 
         public override StandardValuesCollection GetStandardValues(ITypeDescriptorContext context)
         {
-            Hash = GetConvertHash();
+            Hash = GetConvertHash(context);
 
             string[] ids = new string[Hash.Values.Count];
             int i = 0;
@@ -216,7 +218,26 @@
                 {
                     return (value as IComplexDisplay).GetDisplayText();
                 }
-                else
+                else if (value is IEnumerable enumList)
+                {
+                    string display = "";
+                    bool iComplexDisplayMatch = false;
+                    var enumrator = enumList.GetEnumerator();
+                    while (enumrator.MoveNext())
+                    {
+                        if (enumrator.Current is IComplexDisplay d)
+                        {
+                            iComplexDisplayMatch = true;
+                            display += $"{d.GetDisplayText()} ";
+                        }
+                    }
+
+                    if (iComplexDisplayMatch)
+                    {
+                        return display.Trim();
+                    }
+                }
+
                 {
                     return JsonConvert.SerializeObject(value);
                 }
@@ -571,7 +592,7 @@
                 }
 
                 form.ShowDialog();
-                List<string> returnStrs = tbox.Text.Split(new char[] { '\r', '\n' }, StringSplitOptions.RemoveEmptyEntries).ToList();
+                List<string> returnStrs = tbox.Text.Split(new char[] { '\r', '\n', ',' }, StringSplitOptions.RemoveEmptyEntries).ToList();
 
                 switch (typeof(T).Name)
                 {
@@ -624,10 +645,10 @@
             return form;
         }
 
-        //protected override object CreateInstance(Type itemType)
-        //{
-        //    return base.CreateInstance(itemType);
-        //}
+        protected override object CreateInstance(Type itemType)
+        {
+            return base.CreateInstance(itemType);
+        }
 
         //protected override object[] GetItems(object editValue)
         //{
@@ -816,7 +837,7 @@
         }
     }
 
-    public class DeviceTypeConverter : StringConverter 
+    public class DeviceTypeConverter : StringConverter
     {
         public override bool GetStandardValuesSupported(ITypeDescriptorContext context)
         {
@@ -847,7 +868,7 @@
             return new StandardValuesCollection(devices);
         }
     }
-    
+
     public class DeviceInitialConfigEditor<T> : UITypeEditor where T : class, IInitialConfig
     {
         public override UITypeEditorEditStyle GetEditStyle(System.ComponentModel.ITypeDescriptorContext context)
@@ -895,7 +916,7 @@
 
             return base.EditValue(context, provider, value);
         }
-    }
+    }    
     #endregion
 
 }

--
Gitblit v1.8.0