GPSTrackerLocationGrid.cs 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Windows.Controls;
  5. using Comal.Classes;
  6. using Comal.Stores;
  7. using InABox.Clients;
  8. using InABox.Core;
  9. using InABox.DynamicGrid;
  10. using InABox.WPF;
  11. namespace PRSDesktop
  12. {
  13. internal class GPSTrackerLocationGrid : DynamicOneToManyGrid<GPSTracker, GPSTrackerLocation>
  14. {
  15. private static List<Tuple<double, double, string>> _cache;
  16. protected override void Init()
  17. {
  18. base.Init();
  19. Criteria.Add(
  20. new Filter<GPSTrackerLocation>(x => x.Location.Timestamp).IsGreaterThanOrEqualTo(DateTime.Now.AddDays(-1))
  21. );
  22. ActionColumns.Add(new DynamicMapColumn<GPSTrackerLocation>(this, x => x.Location));
  23. AddButton("Get Addresses", null, GetAddressClick);
  24. }
  25. protected override void DoReconfigure(FluentList<DynamicGridOption> options)
  26. {
  27. base.DoReconfigure(options);
  28. options.AddRange(
  29. DynamicGridOption.SelectColumns,
  30. DynamicGridOption.RecordCount,
  31. DynamicGridOption.FilterRows
  32. );
  33. }
  34. public string ReverseGeocode(double latitude, double longitude)
  35. {
  36. if (_cache == null)
  37. _cache = new Client<GPSTrackerLocation>().Query(
  38. new Filter<GPSTrackerLocation>(x => x.Location.Address).IsNotEqualTo(""),
  39. new Columns<GPSTrackerLocation>(
  40. x => x.Location.Address,
  41. x => x.Location.Longitude,
  42. x => x.Location.Latitude
  43. )
  44. ).Rows.Select(r => new Tuple<double, double, string>(
  45. r.Get<GPSTrackerLocation, double>(c => c.Location.Latitude),
  46. r.Get<GPSTrackerLocation, double>(c => c.Location.Longitude),
  47. r.Get<GPSTrackerLocation, string>(c => c.Location.Address)
  48. )).ToList();
  49. var tuple = _cache.FirstOrDefault(x => Equals(x.Item1, latitude) && Equals(x.Item2, longitude));
  50. if (tuple == null)
  51. {
  52. var address = StoreUtils.ReverseGeocode(latitude, longitude);
  53. if (!string.IsNullOrWhiteSpace(address))
  54. {
  55. tuple = new Tuple<double, double, string>(latitude, longitude, address);
  56. _cache.Add(tuple);
  57. }
  58. }
  59. return tuple != null ? tuple.Item3 : "";
  60. }
  61. private bool GetAddressClick(Button arg1, CoreRow[] arg2)
  62. {
  63. var result = false;
  64. var rows = Data.Rows.Where(r =>
  65. string.IsNullOrWhiteSpace(r.Get<GPSTrackerLocation, string>(c => c.Location.Address))
  66. && !Equals(r.Get<GPSTrackerLocation, double>(c => c.Location.Latitude), 0.0F)
  67. && !Equals(r.Get<GPSTrackerLocation, double>(c => c.Location.Longitude), 0.0F)
  68. );
  69. Progress.ShowModal("Updating Addresses", progress =>
  70. {
  71. foreach (var row in rows)
  72. {
  73. var item = LoadItem(row);
  74. var address = ReverseGeocode(
  75. row.Get<GPSTrackerLocation, double>(x => x.Location.Latitude),
  76. row.Get<GPSTrackerLocation, double>(x => x.Location.Longitude)
  77. );
  78. if (!string.IsNullOrWhiteSpace(address))
  79. {
  80. item.Location.Address = address;
  81. UpdateRow<GPSTrackerLocation, string>(row, x => x.Location.Address, address, false);
  82. result = true;
  83. }
  84. }
  85. });
  86. return result;
  87. }
  88. }
  89. }