| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 | 
							- using Newtonsoft.Json;
 
- using Newtonsoft.Json.Linq;
 
- using System;
 
- using System.Collections.Generic;
 
- using System.Data;
 
- using System.Linq;
 
- using System.Text;
 
- using System.Threading.Tasks;
 
- namespace PTMedicalInsurance.Helper
 
- {
 
-     class ReadDataTableConverter : JsonConverter
 
-     {
 
-         public override bool CanConvert(Type objectType)
 
-         {
 
-             return objectType == typeof(DataTable);
 
-         }
 
-         public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
 
-         {
 
-             JArray array = JArray.Load(reader);
 
-             var dataTypes = DetermineColumnDataTypes(array);
 
-             var table = BuildDataTable(array, dataTypes);
 
-             return table;
 
-         }
 
-         private DataTable BuildDataTable(JArray array, Dictionary<string, Type> dataTypes)
 
-         {
 
-             DataTable table = new DataTable();
 
-             foreach (var kvp in dataTypes)
 
-             {
 
-                 table.Columns.Add(kvp.Key, kvp.Value);
 
-             }
 
-             foreach (JObject item in array.Children<JObject>())
 
-             {
 
-                 DataRow row = table.NewRow();
 
-                 foreach (JProperty prop in item.Properties())
 
-                 {
 
-                     if (prop.Value.Type != JTokenType.Null)
 
-                     {
 
-                         Type dataType = dataTypes[prop.Name];
 
-                         row[prop.Name] = prop.Value.ToObject(dataType);
 
-                     }
 
-                 }
 
-                 table.Rows.Add(row);
 
-             }
 
-             return table;
 
-         }
 
-         private Dictionary<string, Type> DetermineColumnDataTypes(JArray array)
 
-         {
 
-             var dataTypes = new Dictionary<string, Type>();
 
-             foreach (JObject item in array.Children<JObject>())
 
-             {
 
-                 foreach (JProperty prop in item.Properties())
 
-                 {
 
-                     Type currentType = GetDataType(prop.Value.Type);
 
-                     if (currentType != null)
 
-                     {
 
-                         Type previousType;
 
-                         if (!dataTypes.TryGetValue(prop.Name, out previousType) ||
 
-                             (previousType == typeof(long) && currentType == typeof(decimal)))
 
-                         {
 
-                             dataTypes[prop.Name] = currentType;
 
-                         }
 
-                         else if (previousType != currentType)
 
-                         {
 
-                             dataTypes[prop.Name] = typeof(string);
 
-                         }
 
-                     }
 
-                 }
 
-             }
 
-             return dataTypes;
 
-         }
 
-         private Type GetDataType(JTokenType tokenType)
 
-         {
 
-             switch (tokenType)
 
-             {
 
-                 case JTokenType.Null:
 
-                     return null;
 
-                 case JTokenType.String:
 
-                     return typeof(string);
 
-                 case JTokenType.Integer:
 
-                     return typeof(long);
 
-                 case JTokenType.Float:
 
-                     return typeof(decimal);
 
-                 case JTokenType.Boolean:
 
-                     return typeof(bool);
 
-                 case JTokenType.Date:
 
-                     return typeof(DateTime);
 
-                 case JTokenType.TimeSpan:
 
-                     return typeof(TimeSpan);
 
-                 case JTokenType.Guid:
 
-                     return typeof(Guid);
 
-                 case JTokenType.Bytes:
 
-                     return typeof(byte[]);
 
-                 case JTokenType.Array:
 
-                 case JTokenType.Object:
 
-                     throw new JsonException("This converter does not support complex types");
 
-                 default:
 
-                     return typeof(string);
 
-             }
 
-         }
 
-         public override bool CanWrite
 
-         {
 
-             get { return false; }
 
-         }
 
-         public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
 
-         {
 
-             throw new NotImplementedException();
 
-         }
 
-     }
 
- }
 
 
  |