mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
UWP: Preference panel
This commit is contained in:
parent
479afcfb8e
commit
dd2ebce57e
14 changed files with 482 additions and 43 deletions
|
@ -4,4 +4,8 @@
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:local="using:ServoApp">
|
xmlns:local="using:ServoApp">
|
||||||
|
|
||||||
|
<Application.Resources>
|
||||||
|
<XamlControlsResources xmlns="using:Microsoft.UI.Xaml.Controls" />
|
||||||
|
</Application.Resources>
|
||||||
|
|
||||||
</Application>
|
</Application>
|
||||||
|
|
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |
|
@ -8,6 +8,11 @@
|
||||||
#include "BrowserPage.g.cpp"
|
#include "BrowserPage.g.cpp"
|
||||||
#include "DefaultUrl.h"
|
#include "DefaultUrl.h"
|
||||||
|
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.Controls.h"
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.XamlTypeInfo.h"
|
||||||
|
#include "winrt/Windows.UI.Text.h"
|
||||||
|
#include "winrt/Windows.UI.Xaml.Documents.h" // For Run.Text()
|
||||||
|
|
||||||
using namespace std::placeholders;
|
using namespace std::placeholders;
|
||||||
using namespace winrt::Windows::Foundation;
|
using namespace winrt::Windows::Foundation;
|
||||||
using namespace winrt::Windows::UI::Xaml;
|
using namespace winrt::Windows::UI::Xaml;
|
||||||
|
@ -18,6 +23,7 @@ using namespace winrt::Windows::UI::Notifications;
|
||||||
using namespace winrt::Windows::Data::Xml::Dom;
|
using namespace winrt::Windows::Data::Xml::Dom;
|
||||||
|
|
||||||
namespace winrt::ServoApp::implementation {
|
namespace winrt::ServoApp::implementation {
|
||||||
|
|
||||||
BrowserPage::BrowserPage() {
|
BrowserPage::BrowserPage() {
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
BindServoEvents();
|
BindServoEvents();
|
||||||
|
@ -84,13 +90,12 @@ void BrowserPage::BindServoEvents() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserPage::OnURLFocused(Windows::Foundation::IInspectable const &) {
|
void BrowserPage::OnURLFocused(IInspectable const &) {
|
||||||
urlTextbox().SelectAll();
|
urlTextbox().SelectAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserPage::OnURLKeyboardAccelerator(
|
void BrowserPage::OnURLKeyboardAccelerator(
|
||||||
Windows::Foundation::IInspectable const &,
|
IInspectable const &, Input::KeyboardAcceleratorInvokedEventArgs const &) {
|
||||||
Windows::UI::Xaml::Input::KeyboardAcceleratorInvokedEventArgs const &) {
|
|
||||||
urlTextbox().Focus(FocusState::Programmatic);
|
urlTextbox().Focus(FocusState::Programmatic);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,10 +121,7 @@ void BrowserPage::SetTransientMode(bool transient) {
|
||||||
|
|
||||||
void BrowserPage::SetArgs(hstring args) { servoControl().SetArgs(args); }
|
void BrowserPage::SetArgs(hstring args) { servoControl().SetArgs(args); }
|
||||||
|
|
||||||
void BrowserPage::Shutdown() {
|
void BrowserPage::Shutdown() { servoControl().Shutdown(); }
|
||||||
ToastNotificationManager::History().Clear();
|
|
||||||
servoControl().Shutdown();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**** USER INTERACTIONS WITH UI ****/
|
/**** USER INTERACTIONS WITH UI ****/
|
||||||
|
|
||||||
|
@ -148,23 +150,153 @@ void BrowserPage::OnHomeButtonClicked(IInspectable const &,
|
||||||
servoControl().LoadURIOrSearch(DEFAULT_URL);
|
servoControl().LoadURIOrSearch(DEFAULT_URL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Given a pref, update its associated UI control.
|
||||||
|
void BrowserPage::UpdatePref(ServoApp::Pref pref, Controls::Control ctrl) {
|
||||||
|
auto value = pref.Value();
|
||||||
|
auto type = value.as<IPropertyValue>().Type();
|
||||||
|
if (type == PropertyType::Boolean) {
|
||||||
|
ctrl.as<Controls::CheckBox>().IsChecked(unbox_value<bool>(value));
|
||||||
|
} else if (type == PropertyType::Double) {
|
||||||
|
ctrl.as<Microsoft::UI::Xaml::Controls::NumberBox>().Value(
|
||||||
|
unbox_value<double>(value));
|
||||||
|
} else if (type == PropertyType::Int64) {
|
||||||
|
ctrl.as<Microsoft::UI::Xaml::Controls::NumberBox>().Value(
|
||||||
|
(double)unbox_value<int64_t>(value));
|
||||||
|
} else if (type == PropertyType::String) {
|
||||||
|
ctrl.as<Controls::TextBox>().Text(unbox_value<hstring>(value));
|
||||||
|
}
|
||||||
|
auto stack = ctrl.Parent().as<Controls::StackPanel>();
|
||||||
|
auto font = winrt::Windows::UI::Text::FontWeights::Normal();
|
||||||
|
if (!pref.IsDefault()) {
|
||||||
|
font = winrt::Windows::UI::Text::FontWeights::Bold();
|
||||||
|
}
|
||||||
|
stack.Children().GetAt(0).as<Controls::TextBlock>().FontWeight(font);
|
||||||
|
stack.Children().GetAt(2).as<Controls::Button>().IsEnabled(!pref.IsDefault());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve the preference list from Servo and build the preference table.
|
||||||
|
void BrowserPage::BuildPrefList() {
|
||||||
|
// It would be better to use a template and bindings, but the
|
||||||
|
// <ListView> takes too long to generate all the items, and
|
||||||
|
// it's pretty difficiult to have different controls depending
|
||||||
|
// on the pref type.
|
||||||
|
prefList().Children().Clear();
|
||||||
|
for (auto pref : ServoControl().Preferences()) {
|
||||||
|
auto value = pref.Value();
|
||||||
|
auto type = value.as<IPropertyValue>().Type();
|
||||||
|
std::optional<Controls::Control> ctrl;
|
||||||
|
if (type == PropertyType::Boolean) {
|
||||||
|
auto checkbox = Controls::CheckBox();
|
||||||
|
checkbox.IsChecked(unbox_value<bool>(value));
|
||||||
|
checkbox.Click([=](const auto &, auto const &) {
|
||||||
|
auto upref = ServoControl().SetBoolPref(
|
||||||
|
pref.Key(), checkbox.IsChecked().GetBoolean());
|
||||||
|
UpdatePref(upref, checkbox);
|
||||||
|
});
|
||||||
|
ctrl = checkbox;
|
||||||
|
} else if (type == PropertyType::String) {
|
||||||
|
auto textbox = Controls::TextBox();
|
||||||
|
textbox.Text(unbox_value<hstring>(value));
|
||||||
|
textbox.KeyUp([=](const auto &, Input::KeyRoutedEventArgs const &e) {
|
||||||
|
if (e.Key() == Windows::System::VirtualKey::Enter) {
|
||||||
|
auto upref = ServoControl().SetStringPref(pref.Key(), textbox.Text());
|
||||||
|
UpdatePref(upref, textbox);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
ctrl = textbox;
|
||||||
|
} else if (type == PropertyType::Int64) {
|
||||||
|
// Note: These are *not* under Windows::UI:Xaml namespace.
|
||||||
|
auto nbox = Microsoft::UI::Xaml::Controls::NumberBox();
|
||||||
|
nbox.Value((double)unbox_value<int64_t>(value));
|
||||||
|
nbox.SpinButtonPlacementMode(
|
||||||
|
Microsoft::UI::Xaml::Controls::NumberBoxSpinButtonPlacementMode::
|
||||||
|
Inline);
|
||||||
|
nbox.ValueChanged([=](const auto &, const auto &) {
|
||||||
|
int val = (int)nbox.Value();
|
||||||
|
auto upref = ServoControl().SetIntPref(pref.Key(), val);
|
||||||
|
UpdatePref(upref, nbox);
|
||||||
|
});
|
||||||
|
ctrl = nbox;
|
||||||
|
} else if (type == PropertyType::Double) {
|
||||||
|
auto nbox = Microsoft::UI::Xaml::Controls::NumberBox();
|
||||||
|
nbox.Value(unbox_value<double>(value));
|
||||||
|
nbox.ValueChanged([=](const auto &, const auto &) {
|
||||||
|
auto upref =
|
||||||
|
ServoControl().SetIntPref(pref.Key(), (int64_t)nbox.Value());
|
||||||
|
UpdatePref(upref, (Controls::Control &)nbox);
|
||||||
|
});
|
||||||
|
ctrl = nbox;
|
||||||
|
}
|
||||||
|
if (ctrl.has_value()) {
|
||||||
|
auto stack = Controls::StackPanel();
|
||||||
|
stack.Tag(winrt::box_value(pref.Key()));
|
||||||
|
stack.Padding({4, 4, 4, 4});
|
||||||
|
stack.Orientation(Controls::Orientation::Horizontal);
|
||||||
|
auto key = Controls::TextBlock();
|
||||||
|
key.Text(pref.Key());
|
||||||
|
key.Width(350);
|
||||||
|
if (!pref.IsDefault()) {
|
||||||
|
auto font = winrt::Windows::UI::Text::FontWeights::Bold();
|
||||||
|
key.FontWeight(font);
|
||||||
|
}
|
||||||
|
stack.Children().Append(key);
|
||||||
|
ctrl->Width(300);
|
||||||
|
ctrl->Margin({4, 0, 40, 0});
|
||||||
|
stack.Children().Append(*ctrl);
|
||||||
|
auto reset = Controls::Button();
|
||||||
|
reset.Content(winrt::box_value(L"reset"));
|
||||||
|
reset.IsEnabled(!pref.IsDefault());
|
||||||
|
reset.Click([=](const auto &, auto const &) {
|
||||||
|
auto upref = ServoControl().ResetPref(pref.Key());
|
||||||
|
UpdatePref(upref, *ctrl);
|
||||||
|
});
|
||||||
|
stack.Children().Append(reset);
|
||||||
|
prefList().Children().Append(stack);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void BrowserPage::OnPrefererenceSearchboxEdited(
|
||||||
|
IInspectable const &, Input::KeyRoutedEventArgs const &) {
|
||||||
|
auto input = preferenceSearchbox().Text();
|
||||||
|
for (auto element : prefList().Children()) {
|
||||||
|
auto ctrl = (Controls::Control &)element;
|
||||||
|
if (input.size() == 0) {
|
||||||
|
ctrl.Visibility(Visibility::Visible);
|
||||||
|
} else {
|
||||||
|
auto tag = ctrl.Tag();
|
||||||
|
std::wstring key = static_cast<std::wstring>(unbox_value<hstring>(tag));
|
||||||
|
bool not_found = key.find(input) == std::wstring::npos;
|
||||||
|
ctrl.Visibility(not_found ? Visibility::Collapsed : Visibility::Visible);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void BrowserPage::OnDevtoolsButtonClicked(IInspectable const &,
|
void BrowserPage::OnDevtoolsButtonClicked(IInspectable const &,
|
||||||
RoutedEventArgs const &) {
|
RoutedEventArgs const &) {
|
||||||
auto toastTemplate = ToastTemplateType::ToastText01;
|
if (toolbox().Visibility() == Visibility::Visible) {
|
||||||
auto toastXml = ToastNotificationManager::GetTemplateContent(toastTemplate);
|
prefList().Children().Clear();
|
||||||
auto toastTextElements = toastXml.GetElementsByTagName(L"text");
|
toolbox().Visibility(Visibility::Collapsed);
|
||||||
std::wstring message;
|
return;
|
||||||
if (mDevtoolsStatus == DevtoolsStatus::Stopped) {
|
}
|
||||||
message = L"Devtools server hasn't started";
|
|
||||||
} else if (mDevtoolsStatus == DevtoolsStatus::Running) {
|
toolbox().Visibility(Visibility::Visible);
|
||||||
message = L"DevTools server has started on port " +
|
|
||||||
std::to_wstring(mDevtoolsPort);
|
BuildPrefList();
|
||||||
} else if (mDevtoolsStatus == DevtoolsStatus::Failed) {
|
|
||||||
message = L"Error: could not start DevTools";
|
// FIXME: we could use template + binding for this.
|
||||||
|
auto ok = mDevtoolsStatus == DevtoolsStatus::Running ? Visibility::Visible
|
||||||
|
: Visibility::Collapsed;
|
||||||
|
auto ko = mDevtoolsStatus == DevtoolsStatus::Failed ? Visibility::Visible
|
||||||
|
: Visibility::Collapsed;
|
||||||
|
auto wip = mDevtoolsStatus == DevtoolsStatus::Stopped ? Visibility::Visible
|
||||||
|
: Visibility::Collapsed;
|
||||||
|
DevtoolsStatusOK().Visibility(ok);
|
||||||
|
DevtoolsStatusKO().Visibility(ko);
|
||||||
|
DevtoolsStatusWIP().Visibility(wip);
|
||||||
|
if (mDevtoolsStatus == DevtoolsStatus::Running) {
|
||||||
|
DevtoolsPort().Text(std::to_wstring(mDevtoolsPort));
|
||||||
}
|
}
|
||||||
toastTextElements.Item(0).InnerText(message);
|
|
||||||
auto toast = ToastNotification(toastXml);
|
|
||||||
ToastNotificationManager::CreateToastNotifier().Show(toast);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserPage::OnURLEdited(IInspectable const &,
|
void BrowserPage::OnURLEdited(IInspectable const &,
|
||||||
|
@ -177,15 +309,13 @@ void BrowserPage::OnURLEdited(IInspectable const &,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserPage::OnMediaControlsPlayClicked(
|
void BrowserPage::OnMediaControlsPlayClicked(IInspectable const &,
|
||||||
Windows::Foundation::IInspectable const &,
|
RoutedEventArgs const &) {
|
||||||
Windows::UI::Xaml::RoutedEventArgs const &) {
|
|
||||||
servoControl().SendMediaSessionAction(
|
servoControl().SendMediaSessionAction(
|
||||||
static_cast<int32_t>(servo::Servo::MediaSessionActionType::Play));
|
static_cast<int32_t>(servo::Servo::MediaSessionActionType::Play));
|
||||||
}
|
}
|
||||||
void BrowserPage::OnMediaControlsPauseClicked(
|
void BrowserPage::OnMediaControlsPauseClicked(IInspectable const &,
|
||||||
Windows::Foundation::IInspectable const &,
|
RoutedEventArgs const &) {
|
||||||
Windows::UI::Xaml::RoutedEventArgs const &) {
|
|
||||||
servoControl().SendMediaSessionAction(
|
servoControl().SendMediaSessionAction(
|
||||||
static_cast<int32_t>(servo::Servo::MediaSessionActionType::Pause));
|
static_cast<int32_t>(servo::Servo::MediaSessionActionType::Pause));
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,8 @@
|
||||||
|
|
||||||
namespace winrt::ServoApp::implementation {
|
namespace winrt::ServoApp::implementation {
|
||||||
|
|
||||||
|
using namespace winrt::Windows::Foundation;
|
||||||
|
|
||||||
static const hstring SERVO_SCHEME = L"fxr";
|
static const hstring SERVO_SCHEME = L"fxr";
|
||||||
static const hstring SERVO_SCHEME_SLASH_SLASH = L"fxr://";
|
static const hstring SERVO_SCHEME_SLASH_SLASH = L"fxr://";
|
||||||
|
|
||||||
|
@ -42,9 +44,14 @@ public:
|
||||||
Windows::UI::Xaml::RoutedEventArgs const &);
|
Windows::UI::Xaml::RoutedEventArgs const &);
|
||||||
void OnMediaControlsPauseClicked(Windows::Foundation::IInspectable const &,
|
void OnMediaControlsPauseClicked(Windows::Foundation::IInspectable const &,
|
||||||
Windows::UI::Xaml::RoutedEventArgs const &);
|
Windows::UI::Xaml::RoutedEventArgs const &);
|
||||||
|
void OnPrefererenceSearchboxEdited(
|
||||||
|
Windows::Foundation::IInspectable const &,
|
||||||
|
Windows::UI::Xaml::Input::KeyRoutedEventArgs const &);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void UpdatePref(ServoApp::Pref, Windows::UI::Xaml::Controls::Control);
|
||||||
void BindServoEvents();
|
void BindServoEvents();
|
||||||
|
void BuildPrefList();
|
||||||
DevtoolsStatus mDevtoolsStatus = DevtoolsStatus::Stopped;
|
DevtoolsStatus mDevtoolsStatus = DevtoolsStatus::Stopped;
|
||||||
unsigned int mDevtoolsPort = 0;
|
unsigned int mDevtoolsPort = 0;
|
||||||
};
|
};
|
||||||
|
|
|
@ -6,7 +6,11 @@
|
||||||
xmlns:local="using:ServoApp"
|
xmlns:local="using:ServoApp"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:muxc="using:Microsoft.UI.Xaml.Controls"
|
||||||
mc:Ignorable="d">
|
mc:Ignorable="d">
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<Page.Resources>
|
<Page.Resources>
|
||||||
<Style x:Key="NavigationBarButton" TargetType="Button">
|
<Style x:Key="NavigationBarButton" TargetType="Button">
|
||||||
<Setter Property="Background" Value="Transparent"/>
|
<Setter Property="Background" Value="Transparent"/>
|
||||||
|
@ -82,7 +86,9 @@
|
||||||
<Grid VerticalAlignment="Stretch">
|
<Grid VerticalAlignment="Stretch">
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="auto"/>
|
<RowDefinition Height="auto"/>
|
||||||
<RowDefinition Height="*"/>
|
<RowDefinition Height="*" MinHeight="200"/>
|
||||||
|
<RowDefinition Height="auto"/>
|
||||||
|
<RowDefinition Height="auto"/>
|
||||||
<RowDefinition Height="auto"/>
|
<RowDefinition Height="auto"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
<Grid Grid.Row="0" x:Name="navigationBar" Background="{ThemeResource InkToolbarButtonBackgroundThemeBrush}">
|
<Grid Grid.Row="0" x:Name="navigationBar" Background="{ThemeResource InkToolbarButtonBackgroundThemeBrush}">
|
||||||
|
@ -111,7 +117,7 @@
|
||||||
</Button.KeyboardAccelerators>
|
</Button.KeyboardAccelerators>
|
||||||
</Button>
|
</Button>
|
||||||
<Button Style="{StaticResource NavigationBarButton}" x:Name="stopButton" IsTabStop="true" IsEnabled="false" Visibility="Collapsed" Click="OnStopButtonClicked" AutomationProperties.Name="Stop" ToolTipService.ToolTip="Stop">
|
<Button Style="{StaticResource NavigationBarButton}" x:Name="stopButton" IsTabStop="true" IsEnabled="false" Visibility="Collapsed" Click="OnStopButtonClicked" AutomationProperties.Name="Stop" ToolTipService.ToolTip="Stop">
|
||||||
<Image Source="Assets/UI/stop.png" Height="18"></Image>
|
<Image Source="Assets/UI/cross.png" Height="18"></Image>
|
||||||
<Button.KeyboardAccelerators>
|
<Button.KeyboardAccelerators>
|
||||||
<KeyboardAccelerator Key="Escape" Modifiers="None" />
|
<KeyboardAccelerator Key="Escape" Modifiers="None" />
|
||||||
</Button.KeyboardAccelerators>
|
</Button.KeyboardAccelerators>
|
||||||
|
@ -132,9 +138,49 @@
|
||||||
<ProgressRing x:Name="urlbarLoadingIndicator" Margin="10,0"/>
|
<ProgressRing x:Name="urlbarLoadingIndicator" Margin="10,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
</Grid>
|
</Grid>
|
||||||
<local:ServoControl TabIndex="0" x:Name="servoControl" Grid.Row="1"/>
|
<local:ServoControl Grid.Row="1" TabIndex="0" x:Name="servoControl"/>
|
||||||
<ProgressBar x:Name="transientLoadingIndicator" Visibility="Collapsed" Grid.Row="2"/>
|
<muxc:TabView x:Name="toolbox" IsAddTabButtonVisible="False" Grid.Row="2" Visibility="Collapsed" Height="300">
|
||||||
<CommandBar Grid.Row="2" x:Name="mediaControls" Visibility="Collapsed">
|
<muxc:TabView.TabStripFooter>
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
<ColumnDefinition Width="Auto"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Button Grid.Column="1" Style="{StaticResource NavigationBarButton}" x:Name="toolboxCloseButton" IsTabStop="true" Click="OnDevtoolsButtonClicked">
|
||||||
|
<Image Source="Assets/UI/cross.png" Height="18"></Image>
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
</muxc:TabView.TabStripFooter>
|
||||||
|
<muxc:TabViewItem Header="Devtools Server" IsClosable="False">
|
||||||
|
<StackPanel>
|
||||||
|
<TextBlock x:Name="DevtoolsStatusOK" Visibility="Collapsed" Margin="10">
|
||||||
|
<Run>Devtools server is listening on port </Run>
|
||||||
|
<Run FontWeight="Bold" x:Name="DevtoolsPort"></Run>
|
||||||
|
<Run>.</Run>
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock x:Name="DevtoolsStatusKO" Visibility="Collapsed">
|
||||||
|
<Run>Devtools server failed to start.</Run>
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock x:Name="DevtoolsStatusWIP" Visibility="Collapsed">
|
||||||
|
<Run>Devtools server is starting..</Run>
|
||||||
|
</TextBlock>
|
||||||
|
</StackPanel>
|
||||||
|
</muxc:TabViewItem>
|
||||||
|
<muxc:TabViewItem Header="Preferences" IsClosable="False">
|
||||||
|
<Grid VerticalAlignment="Stretch">
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="auto"/>
|
||||||
|
<RowDefinition Height="*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<TextBox Grid.Row="0" Text="" IsTabStop="true" PlaceholderText="Search preferences" x:Name="preferenceSearchbox" VerticalAlignment="Center" KeyUp="OnPrefererenceSearchboxEdited" IsSpellCheckEnabled="False" Margin="3"/>
|
||||||
|
<ScrollViewer Grid.Row="1" VerticalScrollBarVisibility="Auto">
|
||||||
|
<StackPanel x:Name="prefList"/>
|
||||||
|
</ScrollViewer>
|
||||||
|
</Grid>
|
||||||
|
</muxc:TabViewItem>
|
||||||
|
</muxc:TabView>
|
||||||
|
<ProgressBar x:Name="transientLoadingIndicator" Visibility="Collapsed" Grid.Row="3"/>
|
||||||
|
<CommandBar Grid.Row="4" x:Name="mediaControls" Visibility="Collapsed">
|
||||||
<AppBarButton Icon="Play" Label="Play" x:Name="playButton" Visibility="Collapsed" Click="OnMediaControlsPlayClicked"/>
|
<AppBarButton Icon="Play" Label="Play" x:Name="playButton" Visibility="Collapsed" Click="OnMediaControlsPlayClicked"/>
|
||||||
<AppBarButton Icon="Pause" Label="Pause" x:Name="pauseButton" Click="OnMediaControlsPauseClicked"/>
|
<AppBarButton Icon="Pause" Label="Pause" x:Name="pauseButton" Click="OnMediaControlsPauseClicked"/>
|
||||||
</CommandBar>
|
</CommandBar>
|
||||||
|
|
|
@ -907,7 +907,7 @@
|
||||||
<Image Include="Assets\UI\forward.png" />
|
<Image Include="Assets\UI\forward.png" />
|
||||||
<Image Include="Assets\UI\home.png" />
|
<Image Include="Assets\UI\home.png" />
|
||||||
<Image Include="Assets\UI\reload.png" />
|
<Image Include="Assets\UI\reload.png" />
|
||||||
<Image Include="Assets\UI\stop.png" />
|
<Image Include="Assets\UI\cross.png" />
|
||||||
<Image Include="Assets\Wide310x150Logo.scale-100.png" />
|
<Image Include="Assets\Wide310x150Logo.scale-100.png" />
|
||||||
<Image Include="Assets\Wide310x150Logo.scale-200.png" />
|
<Image Include="Assets\Wide310x150Logo.scale-200.png" />
|
||||||
<Image Include="Assets\Wide310x150Logo.scale-400.png" />
|
<Image Include="Assets\Wide310x150Logo.scale-400.png" />
|
||||||
|
@ -948,6 +948,7 @@
|
||||||
<Import Project="..\packages\Microsoft.Windows.CppWinRT.2.0.200316.3\build\native\Microsoft.Windows.CppWinRT.targets" Condition="Exists('..\packages\Microsoft.Windows.CppWinRT.2.0.200316.3\build\native\Microsoft.Windows.CppWinRT.targets')" />
|
<Import Project="..\packages\Microsoft.Windows.CppWinRT.2.0.200316.3\build\native\Microsoft.Windows.CppWinRT.targets" Condition="Exists('..\packages\Microsoft.Windows.CppWinRT.2.0.200316.3\build\native\Microsoft.Windows.CppWinRT.targets')" />
|
||||||
<Import Project="..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets" Condition="Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets')" />
|
<Import Project="..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets" Condition="Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets')" />
|
||||||
<Import Project="..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets" Condition="Exists('..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets')" />
|
<Import Project="..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets" Condition="Exists('..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets')" />
|
||||||
|
<Import Project="..\packages\Microsoft.UI.Xaml.2.4.2\build\native\Microsoft.UI.Xaml.targets" Condition="Exists('..\packages\Microsoft.UI.Xaml.2.4.2\build\native\Microsoft.UI.Xaml.targets')" />
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
|
<Target Name="EnsureNuGetPackageBuildImports" BeforeTargets="PrepareForBuild">
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
|
@ -958,5 +959,6 @@
|
||||||
<Error Condition="!Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.props'))" />
|
<Error Condition="!Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.props')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.props'))" />
|
||||||
<Error Condition="!Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets'))" />
|
<Error Condition="!Exists('..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\OpenXR.Loader.1.0.6.2\build\native\OpenXR.Loader.targets'))" />
|
||||||
<Error Condition="!Exists('..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets'))" />
|
<Error Condition="!Exists('..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\ANGLE.WindowsStore.Servo.2.1.19\build\native\ANGLE.WindowsStore.Servo.targets'))" />
|
||||||
|
<Error Condition="!Exists('..\packages\Microsoft.UI.Xaml.2.4.2\build\native\Microsoft.UI.Xaml.targets')" Text="$([System.String]::Format('$(ErrorText)', '..\packages\Microsoft.UI.Xaml.2.4.2\build\native\Microsoft.UI.Xaml.targets'))" />
|
||||||
</Target>
|
</Target>
|
||||||
</Project>
|
</Project>
|
||||||
|
|
|
@ -148,7 +148,7 @@
|
||||||
<Image Include="Assets\UI\reload.png">
|
<Image Include="Assets\UI\reload.png">
|
||||||
<Filter>Assets\UI</Filter>
|
<Filter>Assets\UI</Filter>
|
||||||
</Image>
|
</Image>
|
||||||
<Image Include="Assets\UI\stop.png">
|
<Image Include="Assets\UI\cross.png">
|
||||||
<Filter>Assets\UI</Filter>
|
<Filter>Assets\UI</Filter>
|
||||||
</Image>
|
</Image>
|
||||||
<Image Include="Assets\UI\home.png">
|
<Image Include="Assets\UI\home.png">
|
||||||
|
@ -901,4 +901,4 @@
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ApplicationDefinition Include="App.xaml" />
|
<ApplicationDefinition Include="App.xaml" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
#include "Servo.h"
|
#include "Servo.h"
|
||||||
#include <EGL/egl.h>
|
#include <EGL/egl.h>
|
||||||
|
#include "../DefaultUrl.h"
|
||||||
|
|
||||||
namespace winrt::servo {
|
namespace winrt::servo {
|
||||||
|
|
||||||
|
@ -130,10 +131,64 @@ Servo::Servo(hstring url, hstring args, GLsizei width, GLsizei height,
|
||||||
: mWindowHeight(height), mWindowWidth(width), mDelegate(aDelegate) {
|
: mWindowHeight(height), mWindowWidth(width), mDelegate(aDelegate) {
|
||||||
SetEnvironmentVariableA("PreviewRuntimeEnabled", "1");
|
SetEnvironmentVariableA("PreviewRuntimeEnabled", "1");
|
||||||
|
|
||||||
|
Windows::Storage::ApplicationDataContainer localSettings =
|
||||||
|
Windows::Storage::ApplicationData::Current().LocalSettings();
|
||||||
|
if (!localSettings.Containers().HasKey(L"servoUserPrefs")) {
|
||||||
|
Windows::Storage::ApplicationDataContainer container =
|
||||||
|
localSettings.CreateContainer(
|
||||||
|
L"servoUserPrefs",
|
||||||
|
Windows::Storage::ApplicationDataCreateDisposition::Always);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto prefs = localSettings.Containers().Lookup(L"servoUserPrefs");
|
||||||
|
|
||||||
|
if (!prefs.Values().HasKey(L"shell.homepage")) {
|
||||||
|
prefs.Values().Insert(L"shell.homepage", box_value(DEFAULT_URL));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!prefs.Values().HasKey(L"dom.webxr.enabled")) {
|
||||||
|
prefs.Values().Insert(L"dom.webxr.enabled", box_value(true));
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<capi::CPref> cprefs;
|
||||||
|
|
||||||
|
for (auto pref : prefs.Values()) {
|
||||||
|
auto key = *hstring2char(pref.Key());
|
||||||
|
auto value = pref.Value();
|
||||||
|
auto type = value.as<Windows::Foundation::IPropertyValue>().Type();
|
||||||
|
capi::CPref pref;
|
||||||
|
pref.key = key;
|
||||||
|
pref.pref_type = capi::CPrefType::Missing;
|
||||||
|
pref.value = NULL;
|
||||||
|
if (type == Windows::Foundation::PropertyType::Boolean) {
|
||||||
|
pref.pref_type = capi::CPrefType::Bool;
|
||||||
|
auto val = unbox_value<bool>(value);
|
||||||
|
pref.value = &val;
|
||||||
|
} else if (type == Windows::Foundation::PropertyType::String) {
|
||||||
|
pref.pref_type = capi::CPrefType::Str;
|
||||||
|
pref.value = *hstring2char(unbox_value<hstring>(value));
|
||||||
|
} else if (type == Windows::Foundation::PropertyType::Int64) {
|
||||||
|
pref.pref_type = capi::CPrefType::Int;
|
||||||
|
auto val = unbox_value<int64_t>(value);
|
||||||
|
pref.value = &val;
|
||||||
|
} else if (type == Windows::Foundation::PropertyType::Double) {
|
||||||
|
pref.pref_type = capi::CPrefType::Float;
|
||||||
|
auto val = unbox_value<double>(value);
|
||||||
|
pref.value = &val;
|
||||||
|
} else if (type == Windows::Foundation::PropertyType::Empty) {
|
||||||
|
pref.pref_type = capi::CPrefType::Missing;
|
||||||
|
} else {
|
||||||
|
log("skipping pref %s. Unknown type", key);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
cprefs.push_back(pref);
|
||||||
|
}
|
||||||
|
|
||||||
|
capi::CPrefList prefsList = {cprefs.size(), cprefs.data()};
|
||||||
|
|
||||||
capi::CInitOptions o;
|
capi::CInitOptions o;
|
||||||
hstring defaultPrefs = L" --pref dom.webxr.enabled --devtools";
|
o.prefs = &prefsList;
|
||||||
o.args = *hstring2char(args + defaultPrefs);
|
o.args = *hstring2char(args + L"--devtools");
|
||||||
o.url = *hstring2char(url);
|
|
||||||
o.width = mWindowWidth;
|
o.width = mWindowWidth;
|
||||||
o.height = mWindowHeight;
|
o.height = mWindowHeight;
|
||||||
o.density = dpi;
|
o.density = dpi;
|
||||||
|
@ -221,6 +276,96 @@ Servo::~Servo() {
|
||||||
CloseHandle(sLogHandle);
|
CloseHandle(sLogHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::SetFloatPref(hstring key, double val) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
capi::set_float_pref(ckey, val);
|
||||||
|
auto updatedPref = WrapPref(capi::get_pref(ckey));
|
||||||
|
SaveUserPref(updatedPref);
|
||||||
|
return updatedPref;
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::SetIntPref(hstring key, int64_t val) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
capi::set_int_pref(ckey, val);
|
||||||
|
auto updatedPref = WrapPref(capi::get_pref(ckey));
|
||||||
|
SaveUserPref(updatedPref);
|
||||||
|
return updatedPref;
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::SetBoolPref(hstring key, bool val) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
capi::set_bool_pref(ckey, val);
|
||||||
|
auto updatedPref = WrapPref(capi::get_pref(ckey));
|
||||||
|
SaveUserPref(updatedPref);
|
||||||
|
return updatedPref;
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::SetStringPref(hstring key, hstring val) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
auto cval = *hstring2char(val);
|
||||||
|
capi::set_str_pref(ckey, cval);
|
||||||
|
auto updatedPref = WrapPref(capi::get_pref(ckey));
|
||||||
|
SaveUserPref(updatedPref);
|
||||||
|
return updatedPref;
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::ResetPref(hstring key) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
capi::reset_pref(ckey);
|
||||||
|
auto updatedPref = WrapPref(capi::get_pref(ckey));
|
||||||
|
SaveUserPref(updatedPref);
|
||||||
|
return updatedPref;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Servo::SaveUserPref(PrefTuple pref) {
|
||||||
|
auto localSettings =
|
||||||
|
Windows::Storage::ApplicationData::Current().LocalSettings();
|
||||||
|
auto values = localSettings.Containers().Lookup(L"servoUserPrefs").Values();
|
||||||
|
auto [key, val, isDefault] = pref;
|
||||||
|
if (isDefault) {
|
||||||
|
values.Remove(key);
|
||||||
|
} else {
|
||||||
|
values.Insert(key, val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::WrapPref(capi::CPref pref) {
|
||||||
|
winrt::Windows::Foundation::IInspectable val;
|
||||||
|
if (pref.pref_type == capi::CPrefType::Bool) {
|
||||||
|
val = box_value(*(capi::get_pref_as_bool(pref.value)));
|
||||||
|
} else if (pref.pref_type == capi::CPrefType::Int) {
|
||||||
|
val = box_value(*(capi::get_pref_as_int(pref.value)));
|
||||||
|
} else if (pref.pref_type == capi::CPrefType::Float) {
|
||||||
|
val = box_value(*(capi::get_pref_as_float(pref.value)));
|
||||||
|
} else if (pref.pref_type == capi::CPrefType::Str) {
|
||||||
|
val = box_value(char2hstring(capi::get_pref_as_str(pref.value)));
|
||||||
|
}
|
||||||
|
auto key = char2hstring(pref.key);
|
||||||
|
auto isDefault = pref.is_default;
|
||||||
|
Servo::PrefTuple t{key, val, isDefault};
|
||||||
|
return t;
|
||||||
|
}
|
||||||
|
|
||||||
|
Servo::PrefTuple Servo::GetPref(hstring key) {
|
||||||
|
auto ckey = *hstring2char(key);
|
||||||
|
return WrapPref(capi::get_pref(ckey));
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<Servo::PrefTuple> Servo::GetPrefs() {
|
||||||
|
if (sServo == nullptr) {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
auto prefs = capi::get_prefs();
|
||||||
|
std::vector<
|
||||||
|
std::tuple<hstring, winrt::Windows::Foundation::IInspectable, bool>>
|
||||||
|
vec;
|
||||||
|
for (auto i = 0; i < prefs.len; i++) {
|
||||||
|
auto pref = WrapPref(prefs.list[i]);
|
||||||
|
vec.push_back(pref);
|
||||||
|
}
|
||||||
|
return vec;
|
||||||
|
}
|
||||||
|
|
||||||
winrt::hstring char2hstring(const char *c_str) {
|
winrt::hstring char2hstring(const char *c_str) {
|
||||||
// FIXME: any better way of doing this?
|
// FIXME: any better way of doing this?
|
||||||
auto str = std::string(c_str);
|
auto str = std::string(c_str);
|
||||||
|
|
|
@ -29,12 +29,23 @@ public:
|
||||||
~Servo();
|
~Servo();
|
||||||
ServoDelegate &Delegate() { return mDelegate; }
|
ServoDelegate &Delegate() { return mDelegate; }
|
||||||
|
|
||||||
|
typedef std::tuple<hstring, winrt::Windows::Foundation::IInspectable, bool>
|
||||||
|
PrefTuple;
|
||||||
|
static std::vector<PrefTuple> GetPrefs();
|
||||||
|
static PrefTuple GetPref(hstring key);
|
||||||
|
static PrefTuple SetBoolPref(hstring key, bool val);
|
||||||
|
static PrefTuple SetStringPref(hstring key, hstring val);
|
||||||
|
static PrefTuple SetIntPref(hstring key, int64_t val);
|
||||||
|
static PrefTuple SetFloatPref(hstring key, double val);
|
||||||
|
static PrefTuple ResetPref(hstring key);
|
||||||
|
|
||||||
typedef capi::CMouseButton MouseButton;
|
typedef capi::CMouseButton MouseButton;
|
||||||
typedef capi::CPromptResult PromptResult;
|
typedef capi::CPromptResult PromptResult;
|
||||||
typedef capi::CContextMenuResult ContextMenuResult;
|
typedef capi::CContextMenuResult ContextMenuResult;
|
||||||
typedef capi::CMediaSessionActionType MediaSessionActionType;
|
typedef capi::CMediaSessionActionType MediaSessionActionType;
|
||||||
typedef capi::CMediaSessionPlaybackState MediaSessionPlaybackState;
|
typedef capi::CMediaSessionPlaybackState MediaSessionPlaybackState;
|
||||||
typedef capi::CDevtoolsServerState DevtoolsServerState;
|
typedef capi::CDevtoolsServerState DevtoolsServerState;
|
||||||
|
typedef capi::CPrefType CPrefType;
|
||||||
|
|
||||||
void PerformUpdates() { capi::perform_updates(); }
|
void PerformUpdates() { capi::perform_updates(); }
|
||||||
void DeInit() { capi::deinit(); }
|
void DeInit() { capi::deinit(); }
|
||||||
|
@ -85,6 +96,8 @@ private:
|
||||||
ServoDelegate &mDelegate;
|
ServoDelegate &mDelegate;
|
||||||
GLsizei mWindowWidth;
|
GLsizei mWindowWidth;
|
||||||
GLsizei mWindowHeight;
|
GLsizei mWindowHeight;
|
||||||
|
static void SaveUserPref(PrefTuple);
|
||||||
|
static PrefTuple WrapPref(capi::CPref cpref);
|
||||||
};
|
};
|
||||||
|
|
||||||
class ServoDelegate {
|
class ServoDelegate {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
#include "ServoControl.h"
|
#include "ServoControl.h"
|
||||||
#include "ServoControl.g.cpp"
|
#include "ServoControl.g.cpp"
|
||||||
|
#include "Pref.g.cpp"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
using namespace std::placeholders;
|
using namespace std::placeholders;
|
||||||
|
@ -275,10 +276,19 @@ hstring ServoControl::LoadURIOrSearch(hstring input) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Doesn't look like a URI. Let's search for the string.
|
// Doesn't look like a URI. Let's search for the string.
|
||||||
hstring searchUri =
|
auto escapedInput = Uri::EscapeComponent(input);
|
||||||
L"https://duckduckgo.com/html/?q=" + Uri::EscapeComponent(input);
|
std::wstring searchUri =
|
||||||
TryLoadUri(searchUri);
|
unbox_value<hstring>(std::get<1>(Servo::GetPref(L"shell.searchpage")))
|
||||||
return searchUri;
|
.c_str();
|
||||||
|
std::wstring keyword = L"%s";
|
||||||
|
size_t start_pos = searchUri.find(keyword);
|
||||||
|
if (start_pos == std::string::npos)
|
||||||
|
searchUri = searchUri + escapedInput;
|
||||||
|
else
|
||||||
|
searchUri.replace(start_pos, keyword.length(), escapedInput);
|
||||||
|
hstring finalUri{searchUri};
|
||||||
|
TryLoadUri(finalUri);
|
||||||
|
return finalUri;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServoControl::SendMediaSessionAction(int32_t action) {
|
void ServoControl::SendMediaSessionAction(int32_t action) {
|
||||||
|
@ -580,4 +590,13 @@ template <typename Callable> void ServoControl::RunOnUIThread(Callable cb) {
|
||||||
Dispatcher().RunAsync(CoreDispatcherPriority::High, cb);
|
Dispatcher().RunAsync(CoreDispatcherPriority::High, cb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Collections::IVector<ServoApp::Pref> ServoControl::Preferences() {
|
||||||
|
std::vector<ServoApp::Pref> prefs;
|
||||||
|
for (auto [key, val, isDefault] : Servo::GetPrefs()) {
|
||||||
|
prefs.push_back(ServoApp::Pref(key, val, isDefault));
|
||||||
|
}
|
||||||
|
return winrt::single_threaded_observable_vector<ServoApp::Pref>(
|
||||||
|
std::move(prefs));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace winrt::ServoApp::implementation
|
} // namespace winrt::ServoApp::implementation
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "ServoControl.g.h"
|
#include "ServoControl.g.h"
|
||||||
|
#include "Pref.g.h"
|
||||||
#include "OpenGLES.h"
|
#include "OpenGLES.h"
|
||||||
#include "Servo.h"
|
#include "Servo.h"
|
||||||
#include "DefaultUrl.h"
|
#include "DefaultUrl.h"
|
||||||
|
@ -7,10 +8,30 @@
|
||||||
using namespace winrt::Windows::Foundation::Collections;
|
using namespace winrt::Windows::Foundation::Collections;
|
||||||
|
|
||||||
namespace winrt::ServoApp::implementation {
|
namespace winrt::ServoApp::implementation {
|
||||||
|
|
||||||
|
struct Pref : PrefT<Pref> {
|
||||||
|
public:
|
||||||
|
Pref(hstring key, IInspectable value, bool isDefault) {
|
||||||
|
mKey = key;
|
||||||
|
mValue = value;
|
||||||
|
mIsDefault = isDefault;
|
||||||
|
};
|
||||||
|
IInspectable Value() { return mValue; }
|
||||||
|
hstring Key() { return mKey; }
|
||||||
|
bool IsDefault() { return mIsDefault; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
hstring mKey;
|
||||||
|
IInspectable mValue;
|
||||||
|
bool mIsDefault;
|
||||||
|
};
|
||||||
|
|
||||||
struct ServoControl : ServoControlT<ServoControl>, public servo::ServoDelegate {
|
struct ServoControl : ServoControlT<ServoControl>, public servo::ServoDelegate {
|
||||||
|
|
||||||
ServoControl();
|
ServoControl();
|
||||||
|
|
||||||
|
Windows::Foundation::Collections::IVector<ServoApp::Pref> Preferences();
|
||||||
|
|
||||||
void GoBack();
|
void GoBack();
|
||||||
void GoForward();
|
void GoForward();
|
||||||
void Reload();
|
void Reload();
|
||||||
|
@ -20,6 +41,36 @@ struct ServoControl : ServoControlT<ServoControl>, public servo::ServoDelegate {
|
||||||
hstring LoadURIOrSearch(hstring);
|
hstring LoadURIOrSearch(hstring);
|
||||||
void SendMediaSessionAction(int32_t);
|
void SendMediaSessionAction(int32_t);
|
||||||
|
|
||||||
|
ServoApp::Pref SetBoolPref(hstring aKey, bool aVal) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::SetBoolPref(aKey, aVal);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
|
ServoApp::Pref SetStringPref(hstring aKey, hstring aVal) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::SetStringPref(aKey, aVal);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
|
ServoApp::Pref SetIntPref(hstring aKey, int64_t aVal) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::SetIntPref(aKey, aVal);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
|
ServoApp::Pref SetFloatPref(hstring aKey, double aVal) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::SetFloatPref(aKey, aVal);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
|
ServoApp::Pref ResetPref(hstring aKey) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::ResetPref(aKey);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
|
ServoApp::Pref GetPref(hstring aKey) {
|
||||||
|
auto [key, val, isDefault] = servo::Servo::GetPref(aKey);
|
||||||
|
return ServoApp::Pref(key, val, isDefault);
|
||||||
|
}
|
||||||
|
|
||||||
void OnLoaded(IInspectable const &,
|
void OnLoaded(IInspectable const &,
|
||||||
Windows::UI::Xaml::RoutedEventArgs const &);
|
Windows::UI::Xaml::RoutedEventArgs const &);
|
||||||
|
|
||||||
|
@ -223,4 +274,5 @@ private:
|
||||||
namespace winrt::ServoApp::factory_implementation {
|
namespace winrt::ServoApp::factory_implementation {
|
||||||
struct ServoControl
|
struct ServoControl
|
||||||
: ServoControlT<ServoControl, implementation::ServoControl> {};
|
: ServoControlT<ServoControl, implementation::ServoControl> {};
|
||||||
|
struct Pref : PrefT<Pref, implementation::Pref> {};
|
||||||
} // namespace winrt::ServoApp::factory_implementation
|
} // namespace winrt::ServoApp::factory_implementation
|
||||||
|
|
|
@ -11,6 +11,14 @@ namespace ServoApp {
|
||||||
Failed,
|
Failed,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
runtimeclass Pref
|
||||||
|
{
|
||||||
|
Pref(String key, IInspectable val, Boolean isDefault);
|
||||||
|
IInspectable Value { get; };
|
||||||
|
String Key { get; };
|
||||||
|
Boolean IsDefault { get; };
|
||||||
|
}
|
||||||
|
|
||||||
runtimeclass ServoControl : Windows.UI.Xaml.Controls.Control {
|
runtimeclass ServoControl : Windows.UI.Xaml.Controls.Control {
|
||||||
ServoControl();
|
ServoControl();
|
||||||
void GoBack();
|
void GoBack();
|
||||||
|
@ -33,5 +41,12 @@ namespace ServoApp {
|
||||||
event Windows.Foundation.EventHandler<String> OnURLChanged;
|
event Windows.Foundation.EventHandler<String> OnURLChanged;
|
||||||
event MediaSessionMetadataDelegate OnMediaSessionMetadata;
|
event MediaSessionMetadataDelegate OnMediaSessionMetadata;
|
||||||
event Windows.Foundation.EventHandler<int> OnMediaSessionPlaybackStateChange;
|
event Windows.Foundation.EventHandler<int> OnMediaSessionPlaybackStateChange;
|
||||||
|
Windows.Foundation.Collections.IVector<Pref> Preferences { get; };
|
||||||
|
Pref GetPref(String key);
|
||||||
|
Pref SetBoolPref(String key, Boolean val);
|
||||||
|
Pref SetIntPref(String key, Int64 val);
|
||||||
|
Pref SetFloatPref(String key, Double val);
|
||||||
|
Pref SetStringPref(String key, String val);
|
||||||
|
Pref ResetPref(String key);
|
||||||
}
|
}
|
||||||
} // namespace ServoApp
|
} // namespace ServoApp
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<packages>
|
<packages>
|
||||||
<package id="ANGLE.WindowsStore.Servo" version="2.1.19" targetFramework="native" />
|
<package id="ANGLE.WindowsStore.Servo" version="2.1.19" targetFramework="native" />
|
||||||
|
<package id="Microsoft.UI.Xaml" version="2.4.2" targetFramework="native" />
|
||||||
<package id="Microsoft.Windows.CppWinRT" version="2.0.200316.3" targetFramework="native" />
|
<package id="Microsoft.Windows.CppWinRT" version="2.0.200316.3" targetFramework="native" />
|
||||||
<package id="OpenXR.Loader" version="1.0.6.2" targetFramework="native" />
|
<package id="OpenXR.Loader" version="1.0.6.2" targetFramework="native" />
|
||||||
</packages>
|
</packages>
|
|
@ -54,3 +54,8 @@
|
||||||
#include <winrt/Windows.UI.Xaml.Navigation.h>
|
#include <winrt/Windows.UI.Xaml.Navigation.h>
|
||||||
#include <winrt/Windows.UI.Notifications.h>
|
#include <winrt/Windows.UI.Notifications.h>
|
||||||
#include <winrt/Windows.Data.Xml.Dom.h>
|
#include <winrt/Windows.Data.Xml.Dom.h>
|
||||||
|
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.Automation.Peers.h"
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.Controls.Primitives.h"
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.Media.h"
|
||||||
|
#include "winrt/Microsoft.UI.Xaml.XamlTypeInfo.h"
|
Loading…
Add table
Add a link
Reference in a new issue