Azure Mobile Services, Part 1: Listing 3

MainPage.xaml.cs

using System.Collections.Generic;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Navigation;
using System.Threading.Tasks;

// The Blank Page item template is documented at http://go.microsoft.com/fwlink/?LinkId=234238

namespace VSMMobileServiceClient
{
    /// <summary>
    /// An empty page that can be used on its own or navigated to within a Frame.
    /// </summary>
    public sealed partial class MainPage : Page
    {
        List<ContactItem> _contacts;
        ContactItem _item;
        bool _update = false;

        public MainPage()
        {
            this.InitializeComponent();
            ClearItem();
        }

        private async void ClearItem()
        {
            _item = new ContactItem();
            Contact.DataContext = _item;
            Delete.IsEnabled = false;
            _update = false;
            await UpdateStatus(string.Empty);
        }

        private async Task UpdateStatus(string status)
        {
            Status.Text = status;
            await Task.Delay(250);
        }

        /// <summary>
        /// Invoked when this page is about to be displayed in a Frame.
        /// </summary>
        /// <param name="e">Event data that describes how this page was reached.  The Parameter
        /// property is typically used to configure the page.</param>
        protected async override void OnNavigatedTo(NavigationEventArgs e)
        {
            await GetContacts();
        }

        private async Task GetContacts()
        {
            _contacts = await App.MobileService.GetTable<ContactItem>().ToListAsync();
            Contacts.ItemsSource = _contacts;
        }

        private async void Save_Click(object sender, RoutedEventArgs e)
        {
            if (_update)
                await App.MobileService.GetTable<ContactItem>().UpdateAsync(_item);
            else
                await App.MobileService.GetTable<ContactItem>().InsertAsync(_item);

            await UpdateStatus("Saved");
            await GetContacts();
            ClearItem();
        }

        private void Contacts_SelectionChanged(object sender, SelectionChangedEventArgs e)
        {
            var selectedItem = (sender as ListBox).SelectedItem as ContactItem;
            if (selectedItem != null)
            {
                _item = selectedItem;
                Contact.DataContext = _item;
                _update = true;
                Delete.IsEnabled = true;
            }
        }

        private async void Delete_Click(object sender, RoutedEventArgs e)
        {
            await App.MobileService.GetTable<ContactItem>().DeleteAsync(_item);
            await UpdateStatus("Deleted");
            ClearItem();
            await GetContacts();
        }
    }
}

About the Author

Eric Vogel is a Senior Software Developer for Red Cedar Solutions Group in Okemos, Michigan. He is the president of the Greater Lansing User Group for .NET. Eric enjoys learning about software architecture and craftsmanship, and is always looking for ways to create more robust and testable applications. Contact him at [email protected].

comments powered by Disqus

Featured

  • Telerik UI for Blazor Updated

    Progress announced an update to its Telerik UI for Blazor components, targeting Microsoft's open source Blazor framework that lets C# coders create web apps without having to rely upon JavaScript.

  • Infragistics Unveils UI Components for Blazor

    Infragistics, specializing in third-party UI/UX controls and tools, unveiled a new offering targeting Blazor, Microsoft's red-hot open source framework that allows for C#-based web development instead of traditional mainstay JavaScript.

  • AWS Open Sources Tool for Porting .NET Framework Apps to .NET Core

    Leading cloud computing platform Amazon Web Services open sourced the it announced in July for helping users port old .NET Framework applications to the new .NET Core framework.

  • Uno Platform Ports Windows Calculator to Linux

    Uno Platform has ported the famed Windows Calculator, open sourced last year, to Linux as part of a continuing "proof point" effort to demonstrate the reach of what it describes as the sole UI offering available to target Windows, WebAssembly, iOS, macOS, Android and Linux with single-codebase applications coded in C# and XAML.

  • ASP.NET Core OData 8 Preview Supports .NET 5, but with Breaking Changes

    ASP.NET Core OData, which debuted in July 2018, is out in a v8.0 preview that for the first time supports the upcoming .NET 5 milestone release.

Upcoming Events