The AutoHide and Docking button of the toolWindows does not have a localization strings. Same with the document window.
To reproduce: using System.Windows.Forms; using Telerik.WinControls.UI.Docking; namespace Lab.Dock { public partial class DockMDIForm : MainForm { private RadDock radDock = new RadDock(); public DockMDIForm() {
IMPROVE: RadDock - currently when middle click is executed the ActiveWIndows closes instead of the clicked one
Steps to reproduce: 1. Add a new form to a project and set MdiContainer to true 2. Drag a RadDock onto the form and set the AutoDetectMdiChildren to true 3. Add another form to be used as MdiChild 4. Drag a button onto the second form and in the Click event handler add call to this.Close() 5. Run the project and add an MdiChild form to the MdiContainer form. 6. Press the button on the child form. You will see an exception.
changes --------------------------------- event is changed to ItemSelecting - tabstrip now is pageview (documentTabStrip1.TabStripElement.ItemSelecting += new EventHandler<Telerik.WinControls.UI.RadPageViewItemSelectingEventArgs>(TabStripElement_ItemSelecting)) introduce new powefull events for RadDock - SelectedTabChanging / SelectedTabChanged Create a dock with couple of documents. Subscribe to the TabSelecting event of RadTabStripElement and cancel it showing a message box indicating the cancellation. The message box will be shown 5 times.
To reproduce: case #1 Dock a window to RadDock. Drag a window out of the Dock to make it floating. Check the FloatingWindowsCollection. Dock the window again, you will notice that the collection did not change. case #2 Have a RadDock with a docked ToolWindow. Undock the ToolWindow by double-clicking it and dock it back. Now undock it by dragging it. If you now check the FloatingWindows collection you will see that there are two windows with the same name. Resolution: The FloatingWindows property gets a list of the floating windows. Can contain duplicates, empty or hidden toolwindows which are used internally as re-dock targets. Use the ActiveFloatingWindows property instead of it.
To reproduce: Add a RadDock and a DockWindow, AutoHide it, add a RadPropertyGrid to its controls and dock it. Set the SelectedObject of the property grid to the current form and start the application. Edit the BackColor value and you will notice that the window will hide.
To reproduce: Add RadDock and ToolWindow to the RadDock and dock it. Start the application and drag out the ToolWindow. You will notice that when you try to drag it back in the RadDock you are not able to.
To reproduce: Add a RadDock to a Form, add two ToolWindows and dock them. Drag out one of the toolwindows to the edge of the other one until the drag hint is selected and continue dragging out of the form. You will notice that the drag hint is still selected.
To reproduce: Add a RadDock and two ToolWindows with many controls inside (~100). Drag out the one toolwindow and dock it back by dragging. Now drag it out again and dock it by clicking in its title bar and clicking Docked. You will notice that the second way is faster.
To reproduce: 1.Add a RadDock with a ToolWindow and a DocumentWindow. Add several controls to all windows. Use the following code: protected override void OnLoad(EventArgs e) { base.OnLoad(e); if (System.IO.File.Exists(@"..\..\..\layoutTest.xml")) this.radDock1.LoadFromXml(@"..\..\..\layoutTest.xml"); } protected override void OnClosing(CancelEventArgs e) { this.radDock1.SaveToXml(@"..\..\..\layoutTest.xml"); base.OnClosing(e); } 2. Run the application and change the current layout. 3. Close the form and run the application again. The controls which belong to the RadDock's DocumentWindow disappear from the dialog. Workaround: class MyDock : RadDock { protected override void LoadFromXmlCore(System.Xml.XmlReader reader, bool oldXmlFormat) { //stop the base logic //base.LoadFromXmlCore(reader, oldXmlFormat); if (reader == null) { return; } this.ActiveWindow = null; FieldInfo prevActiveWindow = typeof(RadDock).GetField("prevActiveWindow", BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.GetField); prevActiveWindow.SetValue(this, null); //this.prevActiveWindow = null; FieldInfo attachedWindows = typeof(RadDock).GetField("attachedWindows", System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance); SortedList<string, DockWindow> _attachedWindows = attachedWindows.GetValue(this) as SortedList<string, DockWindow>; MethodInfo CleanAutoHideTabs = typeof(RadDock).GetMethod("CleanAutoHideTabs", System.Reflection.BindingFlags.NonPublic | BindingFlags.Instance); CleanAutoHideTabs.Invoke(this, new object[] { _attachedWindows.Values, true }); //this.CleanAutoHideTabs(this.attachedWindows.Values, true); MethodInfo ResetDesiredDockState = typeof(RadDock).GetMethod("ResetDesiredDockState", System.Reflection.BindingFlags.NonPublic | BindingFlags.Instance); ResetDesiredDockState.Invoke(this, null); //this.ResetDesiredDockState(); MethodInfo OnLoadingFromXML = this.DocumentManager.GetType().GetMethod("OnLoadingFromXML", System.Reflection.BindingFlags.NonPublic | BindingFlags.Instance); OnLoadingFromXML.Invoke(this.DocumentManager, null); //this.DocumentManager.OnLoadingFromXML(); if (oldXmlFormat) { this.BeginTransactionBlock(false); MethodInfo LoadFromOldXml = typeof(RadDock).GetMethod("LoadFromOldXml", System.Reflection.BindingFlags.NonPublic | BindingFlags.Instance); LoadFromOldXml.Invoke(this, new object[] {reader}); // this.LoadFromOldXml(reader); this.EndTransactionBlock(); } else { MethodInfo LoadFromNewXml = typeof(RadDock).GetMethod("LoadFromNewXml", System.Reflection.BindingFlags.NonPublic | BindingFlags.Instance); LoadFromNewXml.Invoke(this, new object[] { reader }); // this.LoadFromNewXml(reader); } this.EnsureInitialized(); this.OnLoadedFromXml(); } public override string ThemeClassName { get { return typeof(RadDock).FullName; } } }
To reproduce: - Add RadDock to a blank form and dock a tool window to the bottom. - Add RadRichTextBox to the tool window and set its anchor property to all for sides. - Save and close the form. - Reopen the form, you will notice that the RadRichtextBox has different size.
To reproduce: Add a few ToolWindows to RadDock and start the application. Drag one window out of the form and dock the others inside of it. Dock the window back to the RadDock. You will notice that only the current window will be docked leaving the rest of the windows floating. The correct behavior is the whole window with its child windows to be docked. Workaround: Subscribe to the DockStateChanging and DockStateChanged events and manually add the windows. private IEnumerable<DockWindow> windows; void RadDock_DockStateChanging(object sender, DockStateChangingEventArgs e) { if (e.NewWindow.FloatingParent == null) { this.windows = Enumerable.Empty<DockWindow>(); return; } this.windows = DockHelper.GetDockWindows(e.NewWindow.FloatingParent, true, this.RadDock).Where(x => x != e.NewWindow); } void RadDock_DockStateChanged(object sender, DockWindowEventArgs e) { foreach (DockWindow window in windows) { this.RadDock.DockWindow(window, e.DockWindow.DockTabStrip, DockPosition.Fill); } }
When you add a few DocumentWindows to RadDock and you undock one of them to a floating window, then undock another one in the same floating window you will see two tabs. In the main area the selected tab is bolded, the functionality should be the same in the floating windows For the time being use the following code to manually bold the tabs: this.RadDock.FloatingWindowCreated += RadDock_FloatingWindowCreated; ... void RadDock_FloatingWindowCreated(object sender, FloatingWindowEventArgs e) { e.Window.Controls[0].ControlAdded += Form1_ControlAdded; } void Form1_ControlAdded(object sender, ControlEventArgs e) { DocumentTabStrip tabStrip = e.Control as DocumentTabStrip; tabStrip.ControlAdded -= Form1_ControlAdded; if (tabStrip != null) { tabStrip.SelectedIndexChanged += tabStrip_SelectedIndexChanged; } } void tabStrip_SelectedIndexChanged(object sender, EventArgs e) { DocumentTabStrip tabStrip = sender as DocumentTabStrip; if (tabStrip != null) { foreach (DocumentWindow item in tabStrip.Controls) { item.TabStripItem.ResetValue(RadItem.FontProperty, ValueResetFlags.Local); } tabStrip.SelectedTab.TabStripItem.Font = new Font(tabStrip.SelectedTab.Font.FontFamily, tabStrip.SelectedTab.Font.Size, FontStyle.Bold); } }
To reproduce: Use the following methods which adds host windows to ToolTabStrip and set the ShowItemCloseButton: private void AddDocumentStrip() { // Create and add a document strip to the dock. this.documentstrip = new ToolTabStrip(); this.documentstrip.TabStripAlignment = TabStripAlignment.Top; this.documentstrip.CaptionVisible = false; this.documentstrip.ActionMenuButton.Visibility = ElementVisibility.Hidden; this.DocumentDock.Controls.Add(documentstrip); this.DocumentDock.ShowToolCloseButton = true; } private void radCommandBar1_Click(object sender, EventArgs e) { RadForm testdoc = new RadForm(); // Create a hostwindow to hold the document (so can interact with the dock) HostWindow hostwindow = new HostWindow(); hostwindow.Text = "Document " + DocumentDock.DockWindows.Count.ToString(); hostwindow.ToolCaptionButtons = ToolStripCaptionButtons.Close; // Load the document into the host window hostwindow.LoadContent(testdoc); // Set the floating size when it is undocked Size size = new Size(660, 440); hostwindow.DefaultFloatingSize = size; // Make sure a closed document releases its resources hostwindow.CloseAction = DockWindowCloseAction.CloseAndDispose; // Check if we are opening our first document, requires additional setup //if (currentdocuments.Count == 0) if (DocumentDock.ActiveWindow == null) { if (this.DocumentDock.Controls.Count < 2) { this.documentstrip.Controls.Add(hostwindow); this.documentstrip.CaptionVisible = true; this.DocumentDock.Controls.Add(documentstrip); this.DocumentDock.ShowToolCloseButton = true; } else { ((ToolTabStrip)this.DocumentDock.Controls[1]).Controls.Add(hostwindow); ((ToolTabStrip)this.DocumentDock.Controls[1]).CaptionVisible = true; this.DocumentDock.ShowToolCloseButton = true; } } else { documentstrip.Controls.Add(hostwindow); documentstrip.Show(); } this.documentstrip.Text = "Document " + DocumentDock.DockWindows.Count.ToString(); //Bring Analyzer to the front this.Activate(); } Click the button a few times, close all windows and click again. You will notice that the close button will not be visible in the new windows. Alternatively, you can download the sample project. Workaround: Manually set the ShowItemCloseButton property to each child ToolTabStrip: private void AddDocumentStrip() { // Create and add a document strip to the dock. this.documentstrip = new ToolTabStrip(); this.documentstrip.TabStripAlignment = TabStripAlignment.Top; this.documentstrip.CaptionVisible = false; this.documentstrip.ActionMenuButton.Visibility = ElementVisibility.Hidden; this.DocumentDock.Controls.Add(documentstrip); this.DocumentDock.ShowToolCloseButton = true; } private void radCommandBar1_Click(object sender, EventArgs e) { RadForm testdoc = new RadForm(); // Create a hostwindow to hold the document (so can interact with the dock) HostWindow hostwindow = new HostWindow(); hostwindow.Text = "Document " + DocumentDock.DockWindows.Count.ToString(); hostwindow.ToolCaptionButtons = ToolStripCaptionButtons.Close; // Load the document into the host window hostwindow.LoadContent(testdoc); // Set the floating size when it is undocked Size size = new Size(660, 440); hostwindow.DefaultFloatingSize = size; // Make sure a closed document releases its resources hostwindow.CloseAction = DockWindowCloseAction.CloseAndDispose; // Check if we are opening our first document, requires additional setup //if (currentdocuments.Count == 0) if (DocumentDock.ActiveWindow == null) { if (this.DocumentDock.Controls.Count < 2) { this.documentstrip.Controls.Add(hostwindow); this.documentstrip.CaptionVisible = true; this.DocumentDock.Controls.Add(documentstrip); this.DocumentDock.ShowToolCloseButton = true; } else { ((ToolTabStrip)this.DocumentDock.Controls[1]).Controls.Add(hostwindow); ((ToolTabStrip)this.DocumentDock.Controls[1]).CaptionVisible = true; foreach (ToolTabStrip strip in this.DocumentDock.EnumFrameworkControls<ToolTabStrip>()) { strip.ShowItemCloseButton = true; } } } else { documentstrip.Controls.Add(hostwindow); documentstrip.Show(); } this.documentstrip.Text = "Document " + DocumentDock.DockWindows.Count.ToString(); //Bring Analyzer to the front this.Activate(); }
To reproduce: Use the BugTracker project from the {IntallationFolder}\Examples\BugTracker 1. Change the CloseAction for all DocumentWindows to "Hide". 2. Run the application. 3. Close tab "Bugs" 4. Save the layout, pressing the "Save" button ribbon tab "view" 5. Load the layout. You will notice that the "Bugs" tab is visible but in a invalid state. Workaround: use DocumentWindow.CloseAction = Close or call DocumentWindow.Show method before loading the layout.
http://blogs.msdn.com/b/zainnab/archive/2012/06/19/visual-studio-2012-new-features-preview-tab.aspx
To reproduce: Add a RadDock with RightToLeft - Yes and add a few document windows. You will see that the Tabs will be rendered LeftToRight. The insertion behavior is correct.
To reproduce: Me.RadDock1.DocumentTabsAlignment = Telerik.WinControls.UI.TabStripAlignment.Left Me.RadDock1.DocumentTabsTextOrientation = Telerik.WinControls.UI.TabStripTextOrientation.Vertical Please refer to the attached file. Workaround: Me.RadDock1.DocumentTabsAlignment = Telerik.WinControls.UI.TabStripAlignment.Left Me.RadDock1.DocumentTabsTextOrientation = Telerik.WinControls.UI.TabStripTextOrientation.Vertical For Each d As DocumentWindow In Me.RadDock1.DockWindows.DocumentWindows d.TabStripItem.AngleTransform = 180 Next Or: foreach (DocumentWindow d in this.radDock1.DockWindows.DocumentWindows) { d.TabStripItem.FlipText = true ; }
To reproduce: 1. Add several DocumentWindows and ToolWindows to the RadDock. 2. Add RadButton controls to the available windows. 3. Subscribe to the ActiveWindowChanged event. 4. Run the application and click over the strip item of one ToolWindow. As a result the ActiveWindowChanged event is fired. Click over the RadButton for a DocumentWindow. You will notice that the ActiveWindowChanged event is not fired. Note: When the active DocumentWindow contains controls ,e.g. RadButton, the tab strip item is not bold. Workaround: static RadDock dock; public Form1() { InitializeComponent(); dock = this.radDock1; Application.AddMessageFilter(new MyFilterClass()); } public const int WM_LBUTTONDOWN = 0x0201; public class MyFilterClass : IMessageFilter { public bool PreFilterMessage(ref Message m) { if (m.Msg == WM_LBUTTONDOWN) { Point pt = dock.PointToClient(Cursor.Position); var clickedElement = dock.GetChildAtPoint(pt, GetChildAtPointSkip.Invisible) ; while (!(clickedElement is ToolWindow || clickedElement is DocumentWindow) && clickedElement != null) { ToolTabStrip tabStrip = clickedElement as ToolTabStrip; if (tabStrip != null) { clickedElement = tabStrip.ActiveWindow; } else { clickedElement = clickedElement.GetChildAtPoint(pt, GetChildAtPointSkip.Invisible); } } if (clickedElement != null) { dock.ActiveWindow = clickedElement as DockWindow; } } return false; } } private void radDock1_ActiveWindowChanged(object sender, Telerik.WinControls.UI.Docking.DockWindowEventArgs e) { e.DockWindow.TabStripItem.Font = new Font(e.DockWindow.TabStripItem.Font, FontStyle.Bold); foreach (DocumentWindow dw in this.radDock1.DockWindows.DocumentWindows) { if (dw.Name != e.DockWindow.Name) { dw.TabStripItem.Font = new Font(e.DockWindow.TabStripItem.Font, FontStyle.Regular); } } }