feature: save location
This commit is contained in:
@ -1,7 +1,8 @@
|
||||
using System;
|
||||
using System.Globalization;
|
||||
using System.Linq;
|
||||
using Billing.Languages;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Billing.Models;
|
||||
using Billing.Store;
|
||||
using Billing.UI;
|
||||
@ -13,6 +14,7 @@ namespace Billing.Views
|
||||
{
|
||||
public partial class AddBillPage : BillingPage
|
||||
{
|
||||
private static readonly BindableProperty CheckBillProperty = Helper.Create<Command, AddBillPage>(nameof(CheckBill), defaultValue: new Command(() => { }, () => false));
|
||||
private static readonly BindableProperty AmountProperty = Helper.Create<string, AddBillPage>(nameof(Amount));
|
||||
private static readonly BindableProperty NameProperty = Helper.Create<string, AddBillPage>(nameof(Name));
|
||||
private static readonly BindableProperty CategoryProperty = Helper.Create<Category, AddBillPage>(nameof(Category));
|
||||
@ -22,6 +24,7 @@ namespace Billing.Views
|
||||
private static readonly BindableProperty CreatedTimeProperty = Helper.Create<TimeSpan, AddBillPage>(nameof(CreatedTime));
|
||||
private static readonly BindableProperty NoteProperty = Helper.Create<string, AddBillPage>(nameof(Note));
|
||||
|
||||
public Command CheckBill => (Command)GetValue(CheckBillProperty);
|
||||
public string Amount
|
||||
{
|
||||
get => (string)GetValue(AmountProperty);
|
||||
@ -55,7 +58,6 @@ namespace Billing.Views
|
||||
set => SetValue(NoteProperty, value);
|
||||
}
|
||||
|
||||
public Command CheckBill { get; }
|
||||
public Command SelectCategory { get; }
|
||||
public Command SelectWallet { get; }
|
||||
|
||||
@ -65,11 +67,12 @@ namespace Billing.Views
|
||||
private readonly DateTime createDate;
|
||||
|
||||
private bool categoryChanged;
|
||||
private CancellationTokenSource tokenSource;
|
||||
private Location location;
|
||||
|
||||
public AddBillPage(DateTime date)
|
||||
{
|
||||
createDate = date;
|
||||
CheckBill = new Command(OnCheckBill);
|
||||
SelectCategory = new Command(OnSelectCategory);
|
||||
SelectWallet = new Command(OnSelectWallet);
|
||||
InitializeComponent();
|
||||
@ -81,7 +84,6 @@ namespace Billing.Views
|
||||
public AddBillPage(Bill bill)
|
||||
{
|
||||
this.bill = bill;
|
||||
CheckBill = new Command(OnCheckBill);
|
||||
SelectCategory = new Command(OnSelectCategory);
|
||||
SelectWallet = new Command(OnSelectWallet);
|
||||
InitializeComponent();
|
||||
@ -90,6 +92,15 @@ namespace Billing.Views
|
||||
Initial();
|
||||
}
|
||||
|
||||
protected override void OnDisappearing()
|
||||
{
|
||||
if (tokenSource != null && !tokenSource.IsCancellationRequested)
|
||||
{
|
||||
tokenSource.Cancel();
|
||||
}
|
||||
base.OnDisappearing();
|
||||
}
|
||||
|
||||
private void Initial()
|
||||
{
|
||||
if (bill != null)
|
||||
@ -116,6 +127,41 @@ namespace Billing.Views
|
||||
protected override void OnLoaded()
|
||||
{
|
||||
editorAmount.SetFocus();
|
||||
|
||||
if (App.SaveLocation)
|
||||
{
|
||||
_ = GetCurrentLocation();
|
||||
}
|
||||
else
|
||||
{
|
||||
SetValue(CheckBillProperty, new Command(OnCheckBill));
|
||||
}
|
||||
}
|
||||
|
||||
private async Task GetCurrentLocation()
|
||||
{
|
||||
try
|
||||
{
|
||||
var request = new GeolocationRequest(GeolocationAccuracy.Best, TimeSpan.FromSeconds(10));
|
||||
tokenSource = new CancellationTokenSource();
|
||||
var status = await Helper.CheckAndRequestPermissionAsync<Permissions.LocationWhenInUse>();
|
||||
if (status != PermissionStatus.Granted)
|
||||
{
|
||||
return;
|
||||
}
|
||||
location = await Geolocation.GetLocationAsync(request, tokenSource.Token);
|
||||
}
|
||||
catch (FeatureNotSupportedException) { }
|
||||
catch (FeatureNotEnabledException) { }
|
||||
catch (PermissionException) { }
|
||||
catch (Exception ex)
|
||||
{
|
||||
Helper.Error("location.get", ex);
|
||||
}
|
||||
finally
|
||||
{
|
||||
SetValue(CheckBillProperty, new Command(OnCheckBill));
|
||||
}
|
||||
}
|
||||
|
||||
private async void OnCheckBill()
|
||||
@ -148,26 +194,27 @@ namespace Billing.Views
|
||||
{
|
||||
name = category.Name;
|
||||
}
|
||||
if (bill != null)
|
||||
{
|
||||
bill.Amount = amount;
|
||||
bill.Name = name;
|
||||
bill.CategoryId = category.Id;
|
||||
bill.WalletId = wallet.Id;
|
||||
bill.CreateTime = CreatedDate.Date.Add(CreatedTime);
|
||||
bill.Store = Store;
|
||||
bill.Note = Note;
|
||||
Bill b = bill;
|
||||
if (b == null)
|
||||
{
|
||||
b = new Bill();
|
||||
}
|
||||
b.Amount = amount;
|
||||
b.Name = name;
|
||||
b.CategoryId = category.Id;
|
||||
b.WalletId = wallet.Id;
|
||||
b.CreateTime = CreatedDate.Date.Add(CreatedTime);
|
||||
b.Store = Store;
|
||||
b.Note = Note;
|
||||
if (location != null)
|
||||
{
|
||||
b.Latitude = location.Latitude;
|
||||
b.Longitude = location.Longitude;
|
||||
b.Altitude = location.Altitude;
|
||||
b.Accuracy = location.Accuracy;
|
||||
b.IsGps = location.IsFromMockProvider;
|
||||
}
|
||||
BillChecked?.Invoke(this, bill ?? new Bill
|
||||
{
|
||||
Amount = amount,
|
||||
Name = name,
|
||||
CategoryId = category.Id,
|
||||
WalletId = wallet.Id,
|
||||
CreateTime = CreatedDate.Date.Add(CreatedTime),
|
||||
Store = Store,
|
||||
Note = Note
|
||||
});
|
||||
BillChecked?.Invoke(this, b);
|
||||
|
||||
category.LastAccountId = wallet.Id;
|
||||
category.LastUsed = DateTime.Now;
|
||||
|
Reference in New Issue
Block a user