From 767cdc1f6f6a63ce997fc9476911e2c361f9d402 Mon Sep 17 00:00:00 2001 From: LukePulverenti Date: Wed, 20 Feb 2013 20:33:05 -0500 Subject: Pushing missing changes --- .../ViewModels/SpecialFeatureViewModel.cs | 135 +++++++++++++++++++++ 1 file changed, 135 insertions(+) create mode 100644 MediaBrowser.UI/ViewModels/SpecialFeatureViewModel.cs (limited to 'MediaBrowser.UI/ViewModels/SpecialFeatureViewModel.cs') diff --git a/MediaBrowser.UI/ViewModels/SpecialFeatureViewModel.cs b/MediaBrowser.UI/ViewModels/SpecialFeatureViewModel.cs new file mode 100644 index 000000000..9d7b9d39d --- /dev/null +++ b/MediaBrowser.UI/ViewModels/SpecialFeatureViewModel.cs @@ -0,0 +1,135 @@ +using MediaBrowser.Model.DTO; +using MediaBrowser.Model.Entities; +using MediaBrowser.Model.Net; +using System; +using System.Windows.Media.Imaging; + +namespace MediaBrowser.UI.ViewModels +{ + /// + /// Class SpecialFeatureViewModel + /// + public class SpecialFeatureViewModel : BaseViewModel + { + /// + /// Gets or sets the image download options. + /// + /// The image download options. + public ImageOptions ImageDownloadOptions { get; set; } + + /// + /// The _image width + /// + private double _imageWidth; + /// + /// Gets or sets the width of the image. + /// + /// The width of the image. + public double ImageWidth + { + get { return _imageWidth; } + + set + { + _imageWidth = value; + OnPropertyChanged("ImageWidth"); + } + } + + /// + /// The _image height + /// + private double _imageHeight; + /// + /// Gets or sets the height of the image. + /// + /// The height of the image. + public double ImageHeight + { + get { return _imageHeight; } + + set + { + _imageHeight = value; + OnPropertyChanged("ImageHeight"); + } + } + + /// + /// The _item + /// + private DtoBaseItem _item; + /// + /// Gets or sets the item. + /// + /// The item. + public DtoBaseItem Item + { + get { return _item; } + + set + { + _item = value; + OnPropertyChanged("Item"); + OnItemChanged(); + } + } + + /// + /// Gets the time string. + /// + /// The time string. + public string MinutesString + { + get + { + var time = TimeSpan.FromTicks(Item.RunTimeTicks ?? 0); + + var minutes = Math.Round(time.TotalMinutes); + + if (minutes <= 1) + { + return "1 minute"; + } + + return string.Format("{0} minutes", minutes); + } + } + + /// + /// The _image + /// + private BitmapImage _image; + /// + /// Gets the image. + /// + /// The image. + public BitmapImage Image + { + get { return _image; } + set + { + _image = value; + OnPropertyChanged("Image"); + } + } + + /// + /// Called when [item changed]. + /// + private async void OnItemChanged() + { + var options = ImageDownloadOptions ?? new ImageOptions { }; + + options.ImageType = ImageType.Primary; + + try + { + Image = await App.Instance.GetRemoteBitmapAsync(App.Instance.ApiClient.GetImageUrl(Item, options)); + } + catch (HttpException) + { + } + } + } +} -- cgit v1.2.3