Explorar el Código

Template and attributes

master
Kobus hace 6 años
padre
commit
f1933ef0a7

+ 33
- 0
UnivateProperties_API/Containers/Timeshare/WeekDto.cs Ver fichero

1
 using System;
1
 using System;
2
+using System.Collections.Generic;
3
+using System.Linq;
4
+using UnivateProperties_API.Helpers;
2
 using UnivateProperties_API.Model.Timeshare;
5
 using UnivateProperties_API.Model.Timeshare;
3
 
6
 
4
 namespace UnivateProperties_API.Containers.Timeshare
7
 namespace UnivateProperties_API.Containers.Timeshare
10
 
13
 
11
         }
14
         }
12
 
15
 
16
+        public WeekDto(string line)
17
+        {
18
+            List<string> split = line.Split(",").ToList();
19
+            AgentAsRep = false;
20
+            Resort = new ResortDto(split[0].Trim(), split[0].Trim());
21
+            UnitNumber = split[1].Trim();
22
+            WeekNumber = split[2].Trim();
23
+            var size = split[3].Trim();
24
+            if(size.Length == 3 && !size.ToLower().StartsWith('s'))
25
+            {
26
+                int.TryParse(size.Substring(0, 1), out int temp);
27
+                Bedrooms = temp;
28
+                int.TryParse(size.Substring(2, 1), out temp);
29
+                MaxSleep = temp;
30
+            }
31
+            bool currentYear = split[9].Trim() == "Y";
32
+            LevyAmount = Convert.ToDouble(split[5].Trim());
33
+            DateTime tempDate = MyCommon.GetDateFromString(currentYear ? split[6].Trim() : split[13].Trim());
34
+            if(tempDate != DateTime.MinValue)
35
+            {
36
+                ArrivalDate = tempDate;
37
+            }
38
+            tempDate = MyCommon.GetDateFromString(currentYear ? split[7].Trim() : split[14].Trim());
39
+            if(tempDate != DateTime.MinValue)
40
+            {
41
+                DepartureDate = tempDate;
42
+            }
43
+            Region = new RegionDto() { RegionCode = split[24] };
44
+        }
45
+
13
         public WeekDto(TimeshareWeek week)
46
         public WeekDto(TimeshareWeek week)
14
         {
47
         {
15
             Id = week.Id;
48
             Id = week.Id;

+ 2
- 0
UnivateProperties_API/Context/DataContext.cs Ver fichero

110
 
110
 
111
         protected override void OnModelCreating(ModelBuilder modelBuilder)
111
         protected override void OnModelCreating(ModelBuilder modelBuilder)
112
         {
112
         {
113
+            modelBuilder.Entity<Individual>()
114
+                .Ignore(b => b.FullName);
113
             modelBuilder.Entity<SMTPHost>().ToTable("Hosts");
115
             modelBuilder.Entity<SMTPHost>().ToTable("Hosts");
114
             modelBuilder.Entity<UnitConfiguration>()
116
             modelBuilder.Entity<UnitConfiguration>()
115
                 .HasIndex(u => u.Code)
117
                 .HasIndex(u => u.Code)

+ 11
- 0
UnivateProperties_API/Helpers/Attributes/BaseAttribute.cs Ver fichero

1
+using System;
2
+
3
+namespace UnivateProperties_API.Helpers.Attributes
4
+{
5
+    public abstract class BaseAttribute : Attribute
6
+    {
7
+        protected BaseAttribute() { }
8
+
9
+        public abstract object Value { get; }
10
+    }
11
+}

+ 17
- 0
UnivateProperties_API/Helpers/Attributes/VisibleAttribute.cs Ver fichero

1
+namespace UnivateProperties_API.Helpers.Attributes
2
+{
3
+    public class VisibleAttribute : BaseAttribute
4
+    {
5
+        public VisibleAttribute(bool value)
6
+        {
7
+            Value = value;
8
+        }
9
+
10
+        public VisibleAttribute()
11
+        {
12
+            Value = true;
13
+        }
14
+
15
+        public override object Value { get; }
16
+    }
17
+}

+ 16
- 0
UnivateProperties_API/Helpers/Attributes/VisibleInListViewAttribute.cs Ver fichero

1
+namespace UnivateProperties_API.Helpers.Attributes
2
+{
3
+    public class VisibleInListViewAttribute : VisibleAttribute
4
+    {
5
+        public VisibleInListViewAttribute(bool value) : base(value)
6
+        {
7
+        }
8
+
9
+        public VisibleInListViewAttribute() : base()
10
+        {
11
+
12
+        }
13
+
14
+        public override object Value => base.Value;
15
+    }
16
+}

+ 48
- 0
UnivateProperties_API/Helpers/MyCommon.cs Ver fichero

1
 using System;
1
 using System;
2
+using System.Collections.Generic;
3
+using System.Linq;
2
 using System.Text.RegularExpressions;
4
 using System.Text.RegularExpressions;
5
+using UnivateProperties_API.Helpers.Attributes;
3
 
6
 
4
 namespace UnivateProperties_API.Helpers
7
 namespace UnivateProperties_API.Helpers
5
 {
8
 {
6
     public static class MyCommon
9
     public static class MyCommon
7
     {
10
     {
11
+        public static List<string> GetVisibleColumns<T>(T item) where T : new()
12
+        {
13
+            List<string> list = new List<string>();
14
+            var type = item.GetType();
15
+            var properties = type.GetProperties();
16
+            var visibleProperties = properties.Where(x => x.GetCustomAttributes(false).Any(a => a.GetType() == typeof(VisibleInListViewAttribute) && ((a as VisibleInListViewAttribute).Value as bool?) == true)).ToList();
17
+            visibleProperties.ForEach(x => list.Add(x.Name));
18
+            return list;
19
+        }
20
+
21
+        public static string TenderUrl { get; set; }
22
+
23
+        public static DateTime GetDateFromString(string value)
24
+        {
25
+            if (CheckDateDayFirst(value))
26
+            {
27
+                return new DateTime(Convert.ToInt32(value.Substring(6, 4)), Convert.ToInt32(value.Substring(3, 2)), Convert.ToInt32(value.Substring(0, 2)));
28
+            }
29
+            else if (CheckDateYearFirst(value))
30
+            {
31
+                return Convert.ToDateTime(value);
32
+            }
33
+            else return DateTime.MinValue;
34
+        }
35
+
36
+        public static bool CheckDateYearFirst(string value)
37
+        {
38
+            if(value.Length >= 10)
39
+            {
40
+                value = value.Substring(0, 10);
41
+            }
42
+            Regex reggie = new Regex(@"^\d{4}-((0[1-9])|(1[012]))-((0[1-9]|[12]\d)|3[01])$");
43
+            return reggie.IsMatch(value);
44
+        }
45
+
46
+        public static bool CheckDateDayFirst(string value)
47
+        {
48
+            if (value.Length >= 10)
49
+            {
50
+                value = value.Substring(0, 10);
51
+            }
52
+            Regex reggie = new Regex(@"^(?:(?:31(\/|-|\.)(?:0?[13578]|1[02]))\1|(?:(?:29|30)(\/|-|\.)(?:0?[13-9]|1[0-2])\2))(?:(?:1[6-9]|[2-9]\d)?\d{2})$|^(?:29(\/|-|\.)0?2\3(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))$|^(?:0?[1-9]|1\d|2[0-8])(\/|-|\.)(?:(?:0?[1-9])|(?:1[0-2]))\4(?:(?:1[6-9]|[2-9]\d)?\d{2})$");
53
+            return reggie.IsMatch(value);
54
+        }
55
+
8
         public static bool IsValidEmail(string item)
56
         public static bool IsValidEmail(string item)
9
         {
57
         {
10
             if (!string.IsNullOrEmpty(item))
58
             if (!string.IsNullOrEmpty(item))

+ 1
- 5
UnivateProperties_API/Model/Communication/PlaceHolder.cs Ver fichero

1
-using System.ComponentModel.DataAnnotations;
2
-using System.ComponentModel.DataAnnotations.Schema;
1
+using System.ComponentModel.DataAnnotations.Schema;
3
 
2
 
4
 namespace UnivateProperties_API.Model.Communication
3
 namespace UnivateProperties_API.Model.Communication
5
 {
4
 {
6
     public class PlaceHolder : BaseEntity
5
     public class PlaceHolder : BaseEntity
7
     {
6
     {
8
-        [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
9
-        [Key]
10
-        public int Id { get; set; }
11
         public string Name { get; set; }
7
         public string Name { get; set; }
12
         public string BoundToClass { get; set; }
8
         public string BoundToClass { get; set; }
13
         public string BoundToClassDisplay { get; set; }
9
         public string BoundToClassDisplay { get; set; }

+ 17
- 0
UnivateProperties_API/Model/Users/Person.cs Ver fichero

1
 using System.ComponentModel.DataAnnotations;
1
 using System.ComponentModel.DataAnnotations;
2
 using System.ComponentModel.DataAnnotations.Schema;
2
 using System.ComponentModel.DataAnnotations.Schema;
3
+using UnivateProperties_API.Helpers.Attributes;
3
 
4
 
4
 namespace UnivateProperties_API.Model.Users
5
 namespace UnivateProperties_API.Model.Users
5
 {
6
 {
17
         public int? UserId { get; set; }
18
         public int? UserId { get; set; }
18
         public string Name { get; set; }
19
         public string Name { get; set; }
19
         public string Surname { get; set; }
20
         public string Surname { get; set; }
21
+        [NotMapped]
22
+        [VisibleInListView]
23
+        public string FullName
24
+        {
25
+            get
26
+            {
27
+                return $"{Name} {Surname}";
28
+            }
29
+        }
30
+        [VisibleInListView(true)]
20
         [DataType(DataType.EmailAddress)]
31
         [DataType(DataType.EmailAddress)]
21
         public string Email { get; set; }
32
         public string Email { get; set; }
33
+        [VisibleInListView(false)]
22
         [Phone]
34
         [Phone]
23
         public string Telephone { get; set; }
35
         public string Telephone { get; set; }
24
         [Phone]
36
         [Phone]
25
         public string CellNumber { get; set; }
37
         public string CellNumber { get; set; }
26
         public virtual User User { get; set; }
38
         public virtual User User { get; set; }
27
         #endregion Properties
39
         #endregion Properties
40
+
41
+        public override string ToString()
42
+        {
43
+            return $"{Name} {Surname}";
44
+        }
28
     }
45
     }
29
 }
46
 }

+ 74
- 10
UnivateProperties_API/Repository/Timeshare/WeekRepository.cs Ver fichero

1
 using Microsoft.EntityFrameworkCore;
1
 using Microsoft.EntityFrameworkCore;
2
 using System;
2
 using System;
3
 using System.Collections.Generic;
3
 using System.Collections.Generic;
4
+using System.Configuration;
5
+using System.IO;
4
 using System.Linq;
6
 using System.Linq;
7
+using System.Net;
8
+using System.Text;
5
 using UnivateProperties_API.Containers.Timeshare;
9
 using UnivateProperties_API.Containers.Timeshare;
6
 using UnivateProperties_API.Containers.Users;
10
 using UnivateProperties_API.Containers.Users;
7
 using UnivateProperties_API.Context;
11
 using UnivateProperties_API.Context;
12
+using UnivateProperties_API.Helpers;
13
+using UnivateProperties_API.Model.Region;
8
 using UnivateProperties_API.Model.Timeshare;
14
 using UnivateProperties_API.Model.Timeshare;
9
 using UnivateProperties_API.Repository.Region;
15
 using UnivateProperties_API.Repository.Region;
10
 using UnivateProperties_API.Repository.Users;
16
 using UnivateProperties_API.Repository.Users;
40
         public List<WeekDto> GetDtoListAll()
46
         public List<WeekDto> GetDtoListAll()
41
         {
47
         {
42
             List<WeekDto> list = new List<WeekDto>();
48
             List<WeekDto> list = new List<WeekDto>();
43
-            foreach(var item in GetDetailedAll())
49
+            foreach (var item in GetDetailedAll())
44
             {
50
             {
45
                 list.Add(new WeekDto(item));
51
                 list.Add(new WeekDto(item));
46
             }
52
             }
53
+            foreach (var  item in GetTenderWeeks())
54
+            {
55
+                list.Add(item);
56
+            }
47
             return list;
57
             return list;
48
         }
58
         }
49
 
59
 
52
             List<WeekDto> list = new List<WeekDto>();
62
             List<WeekDto> list = new List<WeekDto>();
53
             UserRepository userRepository = new UserRepository(_dbContext);
63
             UserRepository userRepository = new UserRepository(_dbContext);
54
             var user = userRepository.Get(x => x.Id == userId).FirstOrDefault();
64
             var user = userRepository.Get(x => x.Id == userId).FirstOrDefault();
55
-            if(user.IsUserInRole(Role.SuperAdmin))
65
+            if (user.IsUserInRole(Role.SuperAdmin))
56
             {
66
             {
57
                 foreach (var item in GetDetailedAll())
67
                 foreach (var item in GetDetailedAll())
58
                 {
68
                 {
59
                     list.Add(new WeekDto(item));
69
                     list.Add(new WeekDto(item));
60
                 }
70
                 }
61
             }
71
             }
62
-            else if(user.IsUserInRole(Role.Agency))
72
+            else if (user.IsUserInRole(Role.Agency))
63
             {
73
             {
64
                 foreach (var item in GetDetailedAll().Where(x => x.AgencyId == userId))
74
                 foreach (var item in GetDetailedAll().Where(x => x.AgencyId == userId))
65
                 {
75
                 {
102
                 }
112
                 }
103
             }
113
             }
104
             list = list.OrderBy(x => x.RegionName).ToList();
114
             list = list.OrderBy(x => x.RegionName).ToList();
105
-            foreach(var region in list)
115
+            foreach (var region in list)
106
             {
116
             {
107
                 region.OrderResorts();
117
                 region.OrderResorts();
108
-                foreach(var resort in region.Resorts)
118
+                foreach (var resort in region.Resorts)
109
                 {
119
                 {
110
                     resort.Available = allItems.Count(x => x.ResortCode == resort.ResortCode);
120
                     resort.Available = allItems.Count(x => x.ResortCode == resort.ResortCode);
111
                 }
121
                 }
117
         {
127
         {
118
             var list = GetAll();
128
             var list = GetAll();
119
             List<TimeshareWeek> weeklist = new List<TimeshareWeek>();
129
             List<TimeshareWeek> weeklist = new List<TimeshareWeek>();
120
-            foreach(var item in list)
130
+            foreach (var item in list)
121
             {
131
             {
122
                 weeklist.Add(GetDetailedWeek(item));
132
                 weeklist.Add(GetDetailedWeek(item));
123
             }
133
             }
126
 
136
 
127
         private TimeshareWeek GetDetailedWeek(TimeshareWeek week)
137
         private TimeshareWeek GetDetailedWeek(TimeshareWeek week)
128
         {
138
         {
129
-            if(week.AgencyId != null)
139
+            if (week.AgencyId != null)
130
             {
140
             {
131
                 AgencyRepository agency = new AgencyRepository(_dbContext);
141
                 AgencyRepository agency = new AgencyRepository(_dbContext);
132
                 week.Agency = agency.Get(x => x.Id == week.AgencyId).FirstOrDefault();
142
                 week.Agency = agency.Get(x => x.Id == week.AgencyId).FirstOrDefault();
133
             }
143
             }
134
-            if(week.AgentId != null)
144
+            if (week.AgentId != null)
135
             {
145
             {
136
                 AgentRepository agent = new AgentRepository(_dbContext);
146
                 AgentRepository agent = new AgentRepository(_dbContext);
137
                 week.Agent = agent.Get(x => x.Id == week.AgentId).FirstOrDefault();
147
                 week.Agent = agent.Get(x => x.Id == week.AgentId).FirstOrDefault();
170
             // Set starting Status of A1
180
             // Set starting Status of A1
171
             StatusRepository repo = new StatusRepository(_dbContext);
181
             StatusRepository repo = new StatusRepository(_dbContext);
172
             item.Status = repo.GetDetailed(s => s.Code == "A1");
182
             item.Status = repo.GetDetailed(s => s.Code == "A1");
173
-            if(item.Status != null)
183
+            if (item.Status != null)
174
             {
184
             {
175
                 //Create initial
185
                 //Create initial
176
                 item.Status = new Status()
186
                 item.Status = new Status()
224
 
234
 
225
         public void Save()
235
         public void Save()
226
         {
236
         {
227
-            _dbContext.SaveChanges();            
237
+            _dbContext.SaveChanges();
228
         }
238
         }
229
 
239
 
230
         public void Update(TimeshareWeek item)
240
         public void Update(TimeshareWeek item)
271
             id += 1;
281
             id += 1;
272
             return id;
282
             return id;
273
         }
283
         }
284
+
285
+        private List<WeekDto> GetTenderWeeks()
286
+        {
287
+            List<WeekDto> list = new List<WeekDto>();
288
+            HttpWebRequest request = (HttpWebRequest)WebRequest.Create(MyCommon.TenderUrl);
289
+            request.Method = "GET";
290
+            WebResponse response = request.GetResponse();
291
+            using (StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8))
292
+            {
293
+                string result = reader.ReadToEnd();
294
+
295
+                if (result.Length > 0)
296
+                {
297
+                    string cleanLine;
298
+                    string[] lines = result.Split(new char[] { '\n' }, StringSplitOptions.RemoveEmptyEntries);
299
+                    foreach (string line in lines)
300
+                    {
301
+                        cleanLine = line.Replace("<br>", "");
302
+                        cleanLine = line.Replace("<br/>", "");
303
+                        list.Add(new WeekDto(cleanLine));
304
+                    }
305
+                }
306
+            }
307
+            // Check that all regions are same as other
308
+            list
309
+                .Where(x => x.Region != null && x.Region.RegionCode == "FN")
310
+                .ToList()
311
+                .ForEach(x => x.Region.RegionCode = ChangeRegion(x.Region.RegionCode));
312
+            list = GetRegion(list);
313
+            return list;
314
+        }
315
+
316
+        private List<WeekDto> GetRegion(List<WeekDto> list)
317
+        {
318
+            ProvinceRepository province = new ProvinceRepository(_dbContext);
319
+            Province prov = null;
320
+            foreach(var item in list)
321
+            {
322
+                prov = province.GetDetailed(x => x.Code == item.Region.RegionCode);
323
+                item.Region = new RegionDto(prov.Id, prov.Code, prov.Description);
324
+            }
325
+            return list;
326
+        }
327
+
328
+        private string ChangeRegion(string value)
329
+        {
330
+            switch(value)
331
+            {
332
+                case "FN":
333
+                    return "KZN";
334
+                default:
335
+                    return value;
336
+            }
337
+        }
274
     }
338
     }
275
 }
339
 }

+ 5
- 0
UnivateProperties_API/Repository/Users/IndividualRepository.cs Ver fichero

3
 using System.Collections.Generic;
3
 using System.Collections.Generic;
4
 using System.Linq;
4
 using System.Linq;
5
 using UnivateProperties_API.Context;
5
 using UnivateProperties_API.Context;
6
+using UnivateProperties_API.Helpers;
6
 using UnivateProperties_API.Model.Users;
7
 using UnivateProperties_API.Model.Users;
7
 
8
 
8
 namespace UnivateProperties_API.Repository.Users
9
 namespace UnivateProperties_API.Repository.Users
23
 
24
 
24
         public List<Individual> GetAll()
25
         public List<Individual> GetAll()
25
         {
26
         {
27
+            foreach(var item in _dbContext.Individuals.Include("User").ToList())
28
+            {
29
+                var list = MyCommon.GetVisibleColumns(item);
30
+            }
26
             return _dbContext.Individuals.Include("User").ToList();
31
             return _dbContext.Individuals.Include("User").ToList();
27
         }
32
         }
28
 
33
 

+ 2
- 0
UnivateProperties_API/Startup.cs Ver fichero

11
 using System.Text;
11
 using System.Text;
12
 using System.Threading.Tasks;
12
 using System.Threading.Tasks;
13
 using UnivateProperties_API.Context;
13
 using UnivateProperties_API.Context;
14
+using UnivateProperties_API.Helpers;
14
 using UnivateProperties_API.Model.Banks;
15
 using UnivateProperties_API.Model.Banks;
15
 using UnivateProperties_API.Model.Communication;
16
 using UnivateProperties_API.Model.Communication;
16
 using UnivateProperties_API.Model.ProcessFlow;
17
 using UnivateProperties_API.Model.ProcessFlow;
50
             }));
51
             }));
51
             services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
52
             services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);
52
             services.AddDbContext<DataContext>(o => o.UseNpgsql(Configuration.GetConnectionString("DefaultConnection")));
53
             services.AddDbContext<DataContext>(o => o.UseNpgsql(Configuration.GetConnectionString("DefaultConnection")));
54
+            MyCommon.TenderUrl = Configuration.GetConnectionString("TenderConnection");
53
 
55
 
54
             var appSettingsSection = Configuration.GetSection("AppSettings");
56
             var appSettingsSection = Configuration.GetSection("AppSettings");
55
             services.Configure<AppSettings>(appSettingsSection);
57
             services.Configure<AppSettings>(appSettingsSection);

+ 2
- 1
UnivateProperties_API/appsettings.json Ver fichero

9
   },
9
   },
10
   "AllowedHosts": "*",
10
   "AllowedHosts": "*",
11
   "ConnectionStrings": {
11
   "ConnectionStrings": {
12
-    "DefaultConnection": "Server=localhost;Port=5432;Database=Univate;User Id=postgres;Password=prov1s1on;"
12
+    "DefaultConnection": "Server=localhost;Port=5432;Database=Univate;User Id=postgres;Password=prov1s1on;",
13
+    "TenderConnection": "http://www.unipoint-consoft.co.za/nph-srep.exe?cluvavail_test.sch&CLUB=LPA&RESORT=ALL&SUMMARY=N&HEAD=N"
13
   }
14
   }
14
 }
15
 }

Loading…
Cancelar
Guardar