diff Chronosv2/source/Presentation/ViewModel/ClosableViewModel.cs @ 10:443821e55f06

Initial cleaned up add from Codeplex files
author stevenh7776 stevenhollidge@hotmail.com
date Tue, 21 Feb 2012 17:25:44 +0700
parents
children 09d18d6e5f40
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Chronosv2/source/Presentation/ViewModel/ClosableViewModel.cs	Tue Feb 21 17:25:44 2012 +0700
@@ -0,0 +1,207 @@
+/*
+The MIT License
+
+Copyright (c) 2009-2010. Carlos Guzmán Álvarez. http://chronoswpf.codeplex.com/
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+*/
+
+using System;
+using System.Collections.Generic;
+using System.ComponentModel;
+using Chronos.Presentation.Core.ViewModel;
+using Chronos.Presentation.Core.VirtualDesktops;
+using NLog;
+using nRoute.Components;
+using nRoute.Components.Messaging;
+
+namespace Chronos.Presentation.ViewModel
+{
+    /// <summary>
+    /// Base class for closeable view models
+    /// </summary>
+    public abstract class ClosableViewModel 
+        : ViewModelBase, IClosableViewModel
+    {
+        #region · NotifyPropertyChanged Cached Instances ·
+
+        private static readonly PropertyChangedEventArgs IdChangedArgs      = CreateArgs<ClosableViewModel>(x => x.Id);
+        private static readonly PropertyChangedEventArgs TitleChangedArgs   = CreateArgs<ClosableViewModel>(x => x.Title);
+
+        #endregion
+
+        #region · Logger ·
+
+        private static Logger Logger = LogManager.GetCurrentClassLogger();
+
+        #endregion
+
+        #region · Fields ·
+
+        private Guid                    id;
+        private ActionCommand           closeCommand;
+        private string                  title;
+        private List<IChannelObserver>  observers;
+
+        #endregion
+
+        #region · Commands ·
+
+        /// <summary>
+        /// Gets the Close Command
+        /// </summary>
+        public ActionCommand CloseCommand
+        {
+            get
+            {
+                if (this.closeCommand == null)
+                {
+                    this.closeCommand = new ActionCommand
+                    (
+                        () => Close(),
+                        () => CanClose()
+                    );
+                }
+
+                return this.closeCommand;
+            }
+        }
+
+        #endregion
+
+        #region · Properties ·
+
+        /// <summary>
+        /// Gets or sets the unique identifier.
+        /// </summary>
+        /// <value>The id.</value>
+        public Guid Id
+        {
+            get { return this.id; }
+            set
+            {
+                if (this.id != value)
+                {
+                    this.id = value;
+                    this.NotifyPropertyChanged(IdChangedArgs);
+                }
+            }
+        }
+
+        /// <summary>
+        /// Returns the user-friendly name of this object.
+        /// Child classes can set this property to a new value,
+        /// or override it to determine the value on-demand.
+        /// </summary>
+        public virtual string Title
+        {
+            get { return this.title; }
+            set
+            {
+                if (this.title != value)
+                {
+                    this.title = value;
+                    this.NotifyPropertyChanged(TitleChangedArgs);
+                }
+            }
+        }
+
+        #endregion
+
+        #region · Constructors ·
+
+        /// <summary>
+        /// Initializes a new instance of the <see cref="ClosableViewModel"/> class.
+        /// </summary>
+        protected ClosableViewModel()
+            : base()
+        {
+            this.Id         = Guid.NewGuid();
+            this.observers  = new List<IChannelObserver>();
+        }
+
+        #endregion
+
+        #region · Messaging Methods ·
+
+        protected void Subscribe<T>(Action<T> payloadHandler)
+            where T: class
+        {
+            this.Subscribe<T>(payloadHandler, ThreadOption.BackgroundThread);
+        }
+
+        protected void Subscribe<T>(Action<T> payloadHandler, ThreadOption threadOption)
+            where T: class
+        {
+            ChannelObserver<T> observer = new ChannelObserver<T>((l) => payloadHandler(l));
+
+            observer.Subscribe(threadOption);
+
+            this.observers.Add(observer);
+        }
+
+        protected void Publish<T>(T message)
+            where T: class
+        {
+            Channel<T>.Publish(message, true);
+        }
+
+        protected void Publish<T>(T message, bool async)
+            where T: class
+        {
+            Channel<T>.Publish(message, async);
+        }
+
+        #endregion
+
+        #region · Command Actions ·
+
+        /// <summary>
+        /// Determines whether the view related to this view model can be closed.
+        /// </summary>
+        /// <returns>
+        /// 	<c>true</c> if the related view can be closed; otherwise, <c>false</c>.
+        /// </returns>
+        public virtual bool CanClose()
+        {
+            return true;
+        }
+
+        /// <summary>
+        /// Called when the related view is being closed.
+        /// </summary>
+        public virtual void Close()
+        {
+            if (this.observers != null)
+            {
+                this.observers.ForEach(o => o.Unsubscribe());
+                this.observers.Clear();
+                this.observers = null;
+            }
+
+            this.GetService<IVirtualDesktopManager>().Close(this.Id);
+
+            this.id             = Guid.Empty;
+            this.title          = null;
+            this.closeCommand   = null;
+        }
+
+        #endregion
+    }
+}