Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enable dragging with the entire titlebar #1948

Merged
merged 38 commits into from
Jul 18, 2019
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
15a1f48
This definitely works for getting shadow, pointy corners back
zadjii-msft Jul 9, 2019
0bc9969
The window style was _not_ important
zadjii-msft Jul 9, 2019
bf239b6
Still getting a black xaml islands area (the HRGN) when we switch to …
zadjii-msft Jul 9, 2019
22e1023
I don't know if this affects anything.
zadjii-msft Jul 9, 2019
aad9f56
heyo this works.
zadjii-msft Jul 9, 2019
5fd4191
Add more comments and cleanup
zadjii-msft Jul 9, 2019
b02d9eb
Merge branch 'dev/migrie/f/1625-less-round-more-shadow' into dev/migr…
zadjii-msft Jul 10, 2019
5c50804
Try making the button RightCustomContent
zadjii-msft Jul 10, 2019
10bcf6e
* Make the MinMaxClose's drag bar's min size the same as a caption bu…
zadjii-msft Jul 10, 2019
ea1298e
Create a TitlebarControl
zadjii-msft Jul 11, 2019
cf939cc
Fix the MMC buttons not working
zadjii-msft Jul 11, 2019
a6ad655
Make the titlebar less magenta
zadjii-msft Jul 11, 2019
ac1f20b
Resize the drag region as we add/remove tabs
zadjii-msft Jul 11, 2019
1905852
Move the actual MMC handling to the TitlebarControl
zadjii-msft Jul 11, 2019
9040940
Some PR nits, fix the titlebar painting on maximize
zadjii-msft Jul 12, 2019
96c5da2
Merge branch 'dev/migrie/f/1625-less-round-more-shadow' into dev/migr…
zadjii-msft Jul 12, 2019
2636b11
Put the TabRow in our XAML
zadjii-msft Jul 12, 2019
dcdbdca
Merge remote-tracking branch 'origin/master' into dev/migrie/f/newtab…
zadjii-msft Jul 12, 2019
69a78d4
Remove dead code in preparation for review
zadjii-msft Jul 12, 2019
e038b5d
Horrifyingly try Gdi Plus as a solution, that is _wrong_ though
zadjii-msft Jul 15, 2019
faef5c7
Revert "Horrifyingly try Gdi Plus as a solution, that is _wrong_ though"
zadjii-msft Jul 15, 2019
83dc600
This fixes the bottom border but breaks the titlebar painting
zadjii-msft Jul 15, 2019
8712f1e
Fix the NC bottom border
zadjii-msft Jul 15, 2019
08e9d6f
A bunch of the more minor PR nits
zadjii-msft Jul 15, 2019
5704084
Add a MinimizeClick event to the MMCControl
zadjii-msft Jul 15, 2019
1fb6943
Add events for _all_ of the buttons, not just the Minimize btn
zadjii-msft Jul 15, 2019
052fabd
Change hoe setting the titlebar content works
zadjii-msft Jul 15, 2019
4fd75f1
Merge remote-tracking branch 'origin/master' into dev/migrie/f/newtab…
zadjii-msft Jul 15, 2019
bfab953
Move the tab row to the bottom of it's available space
zadjii-msft Jul 15, 2019
ce04e72
Fix the theme reloading
zadjii-msft Jul 15, 2019
8e057ea
Merge remote-tracking branch 'origin/master' into dev/migrie/f/newtab…
zadjii-msft Jul 16, 2019
c4a398b
PR nits from @miniksa
zadjii-msft Jul 16, 2019
bf534c6
Update src/cascadia/WindowsTerminal/NonClientIslandWindow.cpp
zadjii-msft Jul 16, 2019
f0dc01e
Merge remote-tracking branch 'origin/master' into dev/migrie/f/newtab…
zadjii-msft Jul 17, 2019
6e41097
This needed to be fixed, was missed in other PR nits
zadjii-msft Jul 17, 2019
744a27f
runformat
zadjii-msft Jul 18, 2019
e2fde7a
Merge remote-tracking branch 'origin/master' into dev/migrie/f/newtab…
zadjii-msft Jul 18, 2019
dc5b18a
Does this fix the CI build?
zadjii-msft Jul 18, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
50 changes: 28 additions & 22 deletions src/cascadia/TerminalApp/App.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,13 @@ namespace winrt::TerminalApp::implementation
// - <none>
// Return Value:
// - <none>
void App::Create(uint64_t hWnd)
void App::Create()
{
// Assert that we've already loaded our settings. We have to do
// this as a MTA, before the app is Create()'d
WINRT_ASSERT(_loadedInitialSettings);
TraceLoggingRegister(g_hTerminalAppProvider);
_Create(hWnd);
_Create();
}

App::~App()
Expand All @@ -79,7 +79,7 @@ namespace winrt::TerminalApp::implementation
// - Create all of the initial UI elements of the Terminal app.
// * Initializes the first terminal control, using the default profile,
// and adds it to our list of tabs.
void App::_Create(uint64_t parentHwnd)
void App::_Create()
zadjii-msft marked this conversation as resolved.
Show resolved Hide resolved
{
/* !!! TODO
This is not the correct way to host a XAML page. This exists today because we valued
Expand All @@ -92,15 +92,18 @@ namespace winrt::TerminalApp::implementation
_root = terminalPage.as<winrt::Windows::UI::Xaml::Controls::Control>();
_tabContent = terminalPage->TabContent();
_tabRow = terminalPage->TabRow();
_tabView = terminalPage->TabView();
_newTabButton = terminalPage->NewTabButton();
_tabView = _tabRow.TabView();
_newTabButton = _tabRow.NewTabButton();

_minMaxCloseControl = terminalPage->MinMaxCloseControl();
_minMaxCloseControl.ParentWindowHandle(parentHwnd);

if (!_settings->GlobalSettings().GetShowTabsInTitlebar())
if (_settings->GlobalSettings().GetShowTabsInTitlebar())
{
_minMaxCloseControl.Visibility(Visibility::Collapsed);
// Remove the TabView from the page. We'll hang on to it, we need to
// put it in the titlebar.
uint32_t index = 0;
if (terminalPage->Root().Children().IndexOf(_tabRow, index))
{
terminalPage->Root().Children().RemoveAt(index);
}
}

// Event Bindings (Early)
Expand Down Expand Up @@ -456,16 +459,6 @@ namespace winrt::TerminalApp::implementation
winrt::Windows::System::Launcher::LaunchUriAsync({ feedbackUriValue });
}

Windows::UI::Xaml::Controls::Border App::GetDragBar() noexcept
{
if (_minMaxCloseControl)
{
return _minMaxCloseControl.DragBar();
}

return nullptr;
}

// Method Description:
// - Called when the about button is clicked. See _ShowAboutDialog for more info.
// Arguments:
Expand Down Expand Up @@ -755,6 +748,11 @@ namespace winrt::TerminalApp::implementation
return _root;
}

UIElement App::GetTitlebarContent() noexcept
{
return _tabRow;
zadjii-msft marked this conversation as resolved.
Show resolved Hide resolved
}

void App::_SetFocusedTabIndex(int tabIndex)
{
// GH#1117: This is a workaround because _tabView.SelectedIndex(tabIndex)
Expand Down Expand Up @@ -916,7 +914,11 @@ namespace winrt::TerminalApp::implementation
// Initialize the new tab

// Create a Conhost connection based on the values in our settings object.
TerminalConnection::ITerminalConnection connection = TerminalConnection::ConhostConnection(settings.Commandline(), settings.StartingDirectory(), 30, 80, winrt::guid());
TerminalConnection::ITerminalConnection connection = TerminalConnection::ConhostConnection(settings.Commandline(),
zadjii-msft marked this conversation as resolved.
Show resolved Hide resolved
settings.StartingDirectory(),
30,
80,
winrt::guid());

TermControl term{ settings, connection };

Expand Down Expand Up @@ -1303,7 +1305,11 @@ namespace winrt::TerminalApp::implementation
const auto controlSettings = _settings->MakeSettings(realGuid);

// Create a Conhost connection based on the values in our settings object.
TerminalConnection::ITerminalConnection controlConnection = TerminalConnection::ConhostConnection(controlSettings.Commandline(), controlSettings.StartingDirectory(), 30, 80, winrt::guid());
TerminalConnection::ITerminalConnection controlConnection = TerminalConnection::ConhostConnection(controlSettings.Commandline(),
controlSettings.StartingDirectory(),
30,
80,
winrt::guid());

TermControl newControl{ controlSettings, controlConnection };

Expand Down
14 changes: 8 additions & 6 deletions src/cascadia/TerminalApp/App.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,11 +26,12 @@ namespace winrt::TerminalApp::implementation
App();

Windows::UI::Xaml::UIElement GetRoot() noexcept;
Windows::UI::Xaml::UIElement GetTitlebarContent() noexcept;

// Gets the current dragglable area in the non client region of the top level window
Windows::UI::Xaml::Controls::Border GetDragBar() noexcept;
// // Gets the current dragglable area in the non client region of the top level window
zadjii-msft marked this conversation as resolved.
Show resolved Hide resolved
// Windows::UI::Xaml::Controls::Border GetDragBar() noexcept;

void Create(uint64_t hParentWnd);
void Create();
void LoadSettings();

Windows::Foundation::Point GetLaunchDimensions(uint32_t dpi);
Expand All @@ -53,10 +54,11 @@ namespace winrt::TerminalApp::implementation
// (which is a root when the tabs are in the titlebar.)
Windows::UI::Xaml::Controls::Control _root{ nullptr };
Microsoft::UI::Xaml::Controls::TabView _tabView{ nullptr };
Windows::UI::Xaml::Controls::Grid _tabRow{ nullptr };

TerminalApp::TabRowControl _tabRow{ nullptr };
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this was not necessary any longer, yes?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

technically yes, the TabRowControl isn't totally necessary, but I was inclined to keep it, to keep each piece more atomic. If you feel strongly, I can change it back


Windows::UI::Xaml::Controls::Grid _tabContent{ nullptr };
Windows::UI::Xaml::Controls::SplitButton _newTabButton{ nullptr };
winrt::TerminalApp::MinMaxCloseControl _minMaxCloseControl{ nullptr };

std::vector<std::shared_ptr<Tab>> _tabs;

Expand All @@ -71,7 +73,7 @@ namespace winrt::TerminalApp::implementation

std::atomic<bool> _settingsReloadQueued{ false };

void _Create(uint64_t parentHWnd);
void _Create();
void _CreateNewTabFlyout();

fire_and_forget _ShowDialog(const winrt::Windows::Foundation::IInspectable& titleElement,
Expand Down
7 changes: 3 additions & 4 deletions src/cascadia/TerminalApp/App.idl
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,7 @@
namespace TerminalApp
{
delegate void LastTabClosedEventArgs();
[default_interface]
runtimeclass App : Microsoft.Toolkit.Win32.UI.XamlHost.XamlApplication
[default_interface] runtimeclass App : Microsoft.Toolkit.Win32.UI.XamlHost.XamlApplication
{
App();

Expand All @@ -16,12 +15,12 @@ namespace TerminalApp
// then it might look like TermApp just failed to activate, which will
// cause you to chase down the rabbit hole of "why is TermApp not
// registered?" when it definitely is.
void Create(UInt64 hParentWnd);
void Create();

void LoadSettings();

Windows.UI.Xaml.UIElement GetRoot();
Windows.UI.Xaml.Controls.Border GetDragBar{ get; };
Windows.UI.Xaml.UIElement GetTitlebarContent();

Windows.Foundation.Point GetLaunchDimensions(UInt32 dpi);
Boolean GetShowTabsInTitlebar();
Expand Down
49 changes: 8 additions & 41 deletions src/cascadia/TerminalApp/MinMaxCloseControl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,59 +17,26 @@ namespace winrt::TerminalApp::implementation
winrt::Windows::UI::Xaml::Application::LoadComponent(*this, resourceLocator, winrt::Windows::UI::Xaml::Controls::Primitives::ComponentResourceLocation::Nested);
}

uint64_t MinMaxCloseControl::ParentWindowHandle() const
void MinMaxCloseControl::Maximize()
{
return reinterpret_cast<uint64_t>(_window);
winrt::Windows::UI::Xaml::VisualStateManager::GoToState(MaximizeButton(), L"WindowStateMaximized", false);
}

void MinMaxCloseControl::ParentWindowHandle(uint64_t handle)
void MinMaxCloseControl::RestoreDown()
{
_window = reinterpret_cast<HWND>(handle);
winrt::Windows::UI::Xaml::VisualStateManager::GoToState(MaximizeButton(), L"WindowStateNormal", false);
}

void MinMaxCloseControl::_OnMaximize(byte flag)
// These need to be defined here to make the compiler happy. They do nothing
zadjii-msft marked this conversation as resolved.
Show resolved Hide resolved
// on their own, it's up to the control that's embedding us to set a
// callback when these buttons are pressed.
void MinMaxCloseControl::Minimize_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e)
{
if (_window)
{
POINT point1 = {};
::GetCursorPos(&point1);
const LPARAM lParam = MAKELPARAM(point1.x, point1.y);
WINDOWPLACEMENT placement = { sizeof(placement) };
::GetWindowPlacement(_window, &placement);
if (placement.showCmd == SW_SHOWNORMAL)
{
winrt::Windows::UI::Xaml::VisualStateManager::GoToState(this->Maximize(), L"WindowStateMaximized", false);
::PostMessage(_window, WM_SYSCOMMAND, SC_MAXIMIZE | flag, lParam);
}
else if (placement.showCmd == SW_SHOWMAXIMIZED)
{
winrt::Windows::UI::Xaml::VisualStateManager::GoToState(this->Maximize(), L"WindowStateNormal", false);
::PostMessage(_window, WM_SYSCOMMAND, SC_RESTORE | flag, lParam);
}
}
}

void MinMaxCloseControl::Maximize_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e)
{
_OnMaximize(HTMAXBUTTON);
}

void MinMaxCloseControl::DragBar_DoubleTapped(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::Input::DoubleTappedRoutedEventArgs const& e)
{
_OnMaximize(HTCAPTION);
}

void MinMaxCloseControl::Minimize_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e)
{
if (_window)
{
::PostMessage(_window, WM_SYSCOMMAND, SC_MINIMIZE | HTMINBUTTON, 0);
}
}

void MinMaxCloseControl::Close_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e)
{
::PostQuitMessage(0);
}

}
11 changes: 3 additions & 8 deletions src/cascadia/TerminalApp/MinMaxCloseControl.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,17 +15,12 @@ namespace winrt::TerminalApp::implementation
{
MinMaxCloseControl();

void Maximize();
void RestoreDown();

void Minimize_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e);
void Maximize_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e);
void Close_Click(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::RoutedEventArgs const& e);
void DragBar_DoubleTapped(winrt::Windows::Foundation::IInspectable const& sender, winrt::Windows::UI::Xaml::Input::DoubleTappedRoutedEventArgs const& e);

uint64_t ParentWindowHandle() const;
void ParentWindowHandle(uint64_t handle);

private:
void _OnMaximize(byte flag);
HWND _window{ nullptr }; // non-owning handle; should not be freed in the dtor.
};
}

Expand Down
11 changes: 6 additions & 5 deletions src/cascadia/TerminalApp/MinMaxCloseControl.idl
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
namespace TerminalApp
{
[default_interface]
runtimeclass MinMaxCloseControl : Windows.UI.Xaml.Controls.StackPanel
[default_interface] runtimeclass MinMaxCloseControl : Windows.UI.Xaml.Controls.StackPanel
{
MinMaxCloseControl();

Windows.UI.Xaml.Controls.Grid Content{ get; };
Windows.UI.Xaml.Controls.Border DragBar{ get; };
void Maximize();
void RestoreDown();

UInt64 ParentWindowHandle;
Windows.UI.Xaml.Controls.Button MinimizeButton { get; };
Windows.UI.Xaml.Controls.Button MaximizeButton { get; };
Windows.UI.Xaml.Controls.Button CloseButton { get; };
}
}
8 changes: 3 additions & 5 deletions src/cascadia/TerminalApp/MinMaxCloseControl.xaml
Original file line number Diff line number Diff line change
Expand Up @@ -129,17 +129,15 @@
</ResourceDictionary>
</StackPanel.Resources>

<Grid x:Name="Content"></Grid>
<Border Height="36.0" MinWidth="160.0" x:Name="DragBar" Background="{ThemeResource ApplicationPageBackgroundThemeBrush}" DoubleTapped="DragBar_DoubleTapped"/>
<Button Height="36.0" Width="45.0" x:Name="Minimize" Style="{StaticResource CaptionButton}" Click="Minimize_Click"
<Button Height="36.0" MinWidth="45.0" Width="45.0" x:Name="MinimizeButton" Style="{StaticResource CaptionButton}" Click="Minimize_Click"
AutomationProperties.Name="Minimize">
<Button.Resources>
<ResourceDictionary>
<x:String x:Key="CaptionButtonPath">M 0 0 H 10</x:String>
</ResourceDictionary>
</Button.Resources>
</Button>
<Button Height="36.0" Width="45.0" x:Name="Maximize" Style="{StaticResource CaptionButton}" Click="Maximize_Click"
<Button Height="36.0" MinWidth="45.0" Width="45.0" x:Name="MaximizeButton" Style="{StaticResource CaptionButton}" Click="Maximize_Click"
AutomationProperties.Name="Maximize">
<Button.Resources>
<ResourceDictionary>
Expand All @@ -148,7 +146,7 @@
</ResourceDictionary>
</Button.Resources>
</Button>
<Button Height="36.0" Width="45.0" x:Name="Close" Style="{StaticResource CaptionButton}" Click="Close_Click"
<Button Height="36.0" MinWidth="45.0" Width="45.0" x:Name="CloseButton" Style="{StaticResource CaptionButton}" Click="Close_Click"
AutomationProperties.Name="Close">
<Button.Resources>
<ResourceDictionary>
Expand Down
30 changes: 30 additions & 0 deletions src/cascadia/TerminalApp/TabRowControl.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.

#include "pch.h"
#include "TabRowControl.h"

#include "TabRowControl.g.cpp"

using namespace winrt;
using namespace Windows::UI::Xaml;

namespace winrt::TerminalApp::implementation
{
TabRowControl::TabRowControl()
{
// The generated code will by default attempt to load from ms-appx://TerminalApp/TabRowControl.xaml.
// We'll force it to load from the root of the appx instead.
const winrt::Windows::Foundation::Uri resourceLocator{ L"ms-appx:///TabRowControl.xaml" };
winrt::Windows::UI::Xaml::Application::LoadComponent(*this, resourceLocator, winrt::Windows::UI::Xaml::Controls::Primitives::ComponentResourceLocation::Nested);
}

// Method Description:
// - Bound in the Xaml editor to the [+] button.
// Arguments:
// - sender
// - event arguments
void TabRowControl::OnNewTabButtonClick(IInspectable const&, Controls::SplitButtonClickEventArgs const&)
{
}
}
25 changes: 25 additions & 0 deletions src/cascadia/TerminalApp/TabRowControl.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.

#pragma once

#include "winrt/Microsoft.UI.Xaml.Controls.h"

#include "TabRowControl.g.h"

namespace winrt::TerminalApp::implementation
{
struct TabRowControl : TabRowControlT<TabRowControl>
{
TabRowControl();

void OnNewTabButtonClick(Windows::Foundation::IInspectable const& sender, Windows::UI::Xaml::Controls::SplitButtonClickEventArgs const& args);
};
}

namespace winrt::TerminalApp::factory_implementation
{
struct TabRowControl : TabRowControlT<TabRowControl, implementation::TabRowControl>
{
};
}
12 changes: 12 additions & 0 deletions src/cascadia/TerminalApp/TabRowControl.idl
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.

namespace TerminalApp
{
[default_interface] runtimeclass TabRowControl : Windows.UI.Xaml.Controls.Grid
{
TabRowControl();
Windows.UI.Xaml.Controls.SplitButton NewTabButton { get; };
Microsoft.UI.Xaml.Controls.TabView TabView { get; };
}
}
Loading