/// <summary>
        /// Finds the frame identified with given name in the specified context.
        /// </summary>
        /// <param name="name">The frame name.</param>
        /// <param name="context">The framework element providing the context for finding a frame.</param>
        /// <returns>The frame or null if the frame could not be found.</returns>
        public static ModernFrame FindFrame(string name, FrameworkElement context)
        {
            if (context == null)
            {
                throw new ArgumentNullException("context");
            }

            // collect all ancestor frames
            var frames = context.Ancestors().OfType<ModernFrame>().ToArray();

            if (name == null || name == "_self")
            {
                // find first ancestor frame
                return frames.FirstOrDefault();
            }
            if (name == "_parent")
            {
                // find parent frame
                return frames.Skip(1).FirstOrDefault();
            }
            if (name == "_top")
            {
                // find top-most frame
                return frames.LastOrDefault();
            }

            // find ancestor frame having a name matching the target
            var frame = frames.FirstOrDefault(f => f.Name == name);

            if (frame == null)
            {
                // find frame in context scope
                frame = context.FindName(name) as ModernFrame;

                if (frame == null)
                {
                    // find frame in scope of ancestor frame content
                    var parent = frames.FirstOrDefault();
                    if (parent != null && parent.Content != null)
                    {
                        var content = parent.Content as FrameworkElement;
                        if (content != null)
                        {
                            frame = content.FindName(name) as ModernFrame;
                        }
                    }
                }
            }

            return frame;
        }
        public static FantasyFrame FindFrame(String name, FrameworkElement context)
        {
            if (context == null)
            {
                throw new ArgumentNullException("context");
            }

            // collect all ancestor frames
            FantasyFrame[] frames = context.Ancestors().OfType<FantasyFrame>().ToArray();
            if (String.IsNullOrEmpty(name) || name.Equals(FrameSelf))
            {
                // find the first frame.
                return frames.FirstOrDefault();
            }
            if (name.Equals(FrameParent))
            {
                // find parent frame
                return frames.Skip(1).FirstOrDefault();
            }
            if (name.Equals(FrameTop))
            {
                // find top-most frame
                return frames.LastOrDefault();
            }

            // find ancestor frame having a name matching the target
            FantasyFrame frame = frames.FirstOrDefault(f => f.Name == name);
            if (frame == null)
            {
                // find frame in context scope
                frame = context.FindName(name) as FantasyFrame;
                if (frame == null)
                {
                    // find frame in scope of ancestor frame content
                    FantasyFrame parent = frames.FirstOrDefault();
                    if (parent != null && parent.Content != null)
                    {
                        FrameworkElement content = parent.Content as FrameworkElement;
                        if (content != null)
                        {
                            frame = content.FindName(name) as FantasyFrame;
                        }
                    }
                }
            }

            return frame;
        }