Code:
/ DotNET / DotNET / 8.0 / untmp / WIN_WINDOWS / lh_tools_devdiv_wpf / Windows / wcp / Framework / System / Windows / Navigation / PageFunction.cs / 1 / PageFunction.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: // PageFunctions are the "atom" of Structured Navigation, // this is the base element class from which the developer derives // from to enable returning results to a caller. // // History: // ??/10/01: michdav Created // 05/09/03: [....] Moved over to WCP dir. Filled in comments and created generic based class // 04/29/04: [....] Style enabled // 05/13/04: [....] Moved most of the code to PageFunctionBase // //--------------------------------------------------------------------------- using System; using System.Windows.Threading; using System.Collections; using System.Diagnostics; using System.IO; using System.Globalization; using System.Runtime.Serialization.Formatters.Binary; using System.Security.Permissions; using MS.Internal; using MS.Internal.AppModel; using MS.Internal.Utility; using MS.Utility; using System.Windows; using System.Windows.Controls; using System.Windows.Media; using System.Windows.Markup; namespace System.Windows.Navigation { ////// Abstract base class for the generic PageFunction class. /// public abstract class PageFunctionBase : Page { #region Constructors ////// PageFunctionBase constructor /// protected PageFunctionBase() { // Make a new GUID for this ID, set the parent ID to 0-0-0-0-0 PageFunctionId = Guid.NewGuid(); ParentPageFunctionId = Guid.Empty; } #endregion Constructors #region Public Properties ////// When set to true, the pagefunction with this property set and all child page functions will get removed from the journal. /// This allows easy building of "transactioned" UI. If a series of steps have been completed, and it doesn't make sense to hit the back button and submit that transaction again, /// setting this property enables those series of steps to be removed from the journal. /// ////// Examples abound of "transactioned UI" buying a book from an ecommerce application, selling stock, creating a user account. /// public bool RemoveFromJournal { get { return _fRemoveFromJournal; } set { _fRemoveFromJournal = value; } } #endregion Public Properties #region Protected Methods ////// This method is called when a PageFunction is first navigated to. /// It is not called when a Pagefunction resumes. /// ////// Typically a developer will write some initialization code in their Start method, /// or they may decide to invoke a child PageFunction. /// protected virtual void Start() { } /* ////// To be used by derived classes to raise strongly types return events. Must be overriden. /// // protected abstract void RaiseTypedReturnEvent(Delegate d, object returnEventArgs); */ #endregion Protected Methods #region Internal Methods // An internal method which is used to invoke the protected Start() method by // other parts of the PageFunction code base. internal void CallStart() { Start(); } ////// A Pagefunction calls this method to signal that it is completed and the ReturnEventArgs /// will be supplied to the listener on Return ( and that listener will be unsuspended). /// internal void _OnReturnUnTyped(object o) { if (_finish != null) { _finish(this, o); } } internal void _AddEventHandler(Delegate d) { // This is where the parent-child relationship is established. If // PageFunction A attaches one of its methods to PageFunction B's // Return event, then A must be B's parent. PageFunctionBase parent = d.Target as PageFunctionBase; if (parent != null) { ParentPageFunctionId = parent.PageFunctionId; } _returnHandler = Delegate.Combine(_returnHandler, d); } internal void _RemoveEventHandler(Delegate d) { _returnHandler = Delegate.Remove(_returnHandler, d); } internal void _DetachEvents() { _returnHandler = null; } // // Raise the event on the _returnHandler // internal void _OnFinish(object returnEventArgs) { RaiseTypedEventArgs args = new RaiseTypedEventArgs(_returnHandler, returnEventArgs); RaiseTypedEvent(this, args); //RaiseTypedReturnEvent(_returnHandler, returnEventArgs); } #endregion Internal Methods #region Internal Properties ////// This is the GUID for this PageFunction. It will be used as its childrens' /// ParentPageFunctionId. /// internal Guid PageFunctionId { get { return _pageFunctionId; } set { _pageFunctionId = value; } } ////// If this PageFunction is a child PageFunction, this will be the GUID of its /// parent PageFunction. If this is Guid.Empty, then the parent is NOT a /// PageFunction. /// internal Guid ParentPageFunctionId { get { return _parentPageFunctionId; } set { _parentPageFunctionId = value; } } internal Delegate _Return { get { return _returnHandler; } } ////// Whether the PF is being resumed after a child PF returns OR due to journal navigation /// (Go Back/Fwd) /// internal bool _Resume { get { return _resume; } set { _resume = value; } } internal ReturnEventSaver _Saver { get { return _saverInfo; } set { _saverInfo = value; } } #endregion Internal Properties #region Internal Events // // The FinishEventHandler is used to communicate between the NavigationService and the ending Pagefunction // internal FinishEventHandler FinishHandler { get { return _finish; } set { _finish = value; } } internal event EventToRaiseTypedEvent RaiseTypedEvent; #endregion #region Private Fields private Guid _pageFunctionId; private Guid _parentPageFunctionId; private bool _fRemoveFromJournal = true; // new default, to make PFs behave more like functions private bool _resume; private ReturnEventSaver _saverInfo; // keeps track of Parent caller's Return Event Info private FinishEventHandler _finish; private Delegate _returnHandler; // the delegate for the Return event #endregion Private Fields } internal delegate void EventToRaiseTypedEvent(PageFunctionBase sender, RaiseTypedEventArgs args); internal class RaiseTypedEventArgs : System.EventArgs { internal RaiseTypedEventArgs(Delegate d, object o) { D = d; O = o; } internal Delegate D; internal Object O; } ////// A callback handler used to receive a ReturnEventArgs of type T /// public delegate void ReturnEventHandler(object sender, ReturnEventArgs e); /// /// PageFunctions are the "atom" of Structured Navigation, /// this is the base element class from which the developer derives /// from to enable returning results to a caller. /// ////// Right now Pagefunctions are non-cls compliant owing to their use of generics. It is expected in the LH timeframe that /// all CLS languages will support generics. /// public class PageFunction: PageFunctionBase { #region Constructors /// /// Pagefunction constructor /// public PageFunction() { RaiseTypedEvent += new EventToRaiseTypedEvent(RaiseTypedReturnEvent); } #endregion Constructors #region Protected Methods ////// A Pagefunction calls this method to signal that it is completed and the ReturnEventArgs /// will be supplied to the listener on Return ( and that listener will be unsuspended). /// protected virtual void OnReturn(ReturnEventArgse) { _OnReturnUnTyped(e); } /// /// Used to raise a strongly typed return event. Sealed since nobody should have the need to override as /// all derived types of this generic type will automatically get the strongly typed version from this /// generic version. /// internal void RaiseTypedReturnEvent(PageFunctionBase b, RaiseTypedEventArgs args) { Delegate d = args.D; object returnEventArgs = args.O; if (d != null) { ReturnEventArgsra = returnEventArgs as ReturnEventArgs ; Debug.Assert((returnEventArgs == null) || (ra != null)); ReturnEventHandler eh = d as ReturnEventHandler ; Debug.Assert(eh != null); eh(this, ra); } } #endregion Protected Methods #region Public Events /// /// This is the event to which a caller will listen to get results returned. /// public event ReturnEventHandlerReturn { // We need to provide a way to surface out // the listeners to the event // So we override add/remove and keep track of it here. add { _AddEventHandler((Delegate)value); } remove { _RemoveEventHandler((Delegate)value); } } #endregion Public Events } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- EntityRecordInfo.cs
- SectionInput.cs
- PermissionListSet.cs
- TypeBrowser.xaml.cs
- ToolStripContentPanel.cs
- ContainsSearchOperator.cs
- CustomValidator.cs
- CompilationRelaxations.cs
- Positioning.cs
- DoubleLinkList.cs
- validation.cs
- EdmProperty.cs
- RegexCharClass.cs
- ConfigXmlText.cs
- CollectionsUtil.cs
- MtomMessageEncodingBindingElement.cs
- XmlException.cs
- Empty.cs
- EtwTrackingParticipant.cs
- TransformDescriptor.cs
- _ListenerResponseStream.cs
- ValueTypeFixupInfo.cs
- PointF.cs
- ToolStripDropDownClosedEventArgs.cs
- ProtectedConfiguration.cs
- _NegoStream.cs
- SQLInt64.cs
- iisPickupDirectory.cs
- HttpCookie.cs
- WebPartDeleteVerb.cs
- EntityDataSourceDataSelectionPanel.designer.cs
- DesigntimeLicenseContextSerializer.cs
- SafeArrayRankMismatchException.cs
- BamlWriter.cs
- DoubleLink.cs
- MimeObjectFactory.cs
- BinarySerializer.cs
- MoveSizeWinEventHandler.cs
- ZipPackage.cs
- ErrorLog.cs
- MulticastIPAddressInformationCollection.cs
- EntityDataSourceContextCreatedEventArgs.cs
- ServiceModelStringsVersion1.cs
- DataGridHelper.cs
- MsmqOutputMessage.cs
- DefaultWorkflowLoaderService.cs
- AspCompat.cs
- AttributeProviderAttribute.cs
- CatalogZone.cs
- HtmlSelectionListAdapter.cs
- ResolveCriteria11.cs
- PolicyUnit.cs
- httpserverutility.cs
- Transform.cs
- SchemaNamespaceManager.cs
- HttpModulesSection.cs
- AttributeEmitter.cs
- CodeExporter.cs
- AsyncPostBackTrigger.cs
- ContextBase.cs
- UnicodeEncoding.cs
- AsyncCompletedEventArgs.cs
- XmlDataSourceView.cs
- GlobalEventManager.cs
- Rotation3DAnimationBase.cs
- ListControlDesigner.cs
- Label.cs
- PrivilegedConfigurationManager.cs
- XmlDataSourceView.cs
- MaterializeFromAtom.cs
- Point3D.cs
- IsolatedStorageFileStream.cs
- InstalledFontCollection.cs
- EditorAttribute.cs
- SingleBodyParameterMessageFormatter.cs
- DbConnectionFactory.cs
- XmlRootAttribute.cs
- RectangleConverter.cs
- ServiceNameElement.cs
- InstanceContextMode.cs
- HtmlLiteralTextAdapter.cs
- DBConcurrencyException.cs
- Filter.cs
- GetPageNumberCompletedEventArgs.cs
- LiteralDesigner.cs
- EdmProviderManifest.cs
- AddValidationError.cs
- QueryOperationResponseOfT.cs
- ValidatedControlConverter.cs
- VScrollBar.cs
- FormParameter.cs
- TextModifier.cs
- QuadraticBezierSegment.cs
- ValueUnavailableException.cs
- InputElement.cs
- KeyedCollection.cs
- XmlAggregates.cs
- VScrollProperties.cs
- TransmissionStrategy.cs
- HtmlElementErrorEventArgs.cs