diff --git a/Tasks/Lab6/UWPClient/App.xaml b/Tasks/Lab6/UWPClient/App.xaml
new file mode 100644
index 0000000..2e835a2
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/App.xaml
@@ -0,0 +1,7 @@
+
+
+
diff --git a/Tasks/Lab6/UWPClient/App.xaml.cs b/Tasks/Lab6/UWPClient/App.xaml.cs
new file mode 100644
index 0000000..9c1d7e9
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/App.xaml.cs
@@ -0,0 +1,100 @@
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Runtime.InteropServices.WindowsRuntime;
+using Windows.ApplicationModel;
+using Windows.ApplicationModel.Activation;
+using Windows.Foundation;
+using Windows.Foundation.Collections;
+using Windows.UI.Xaml;
+using Windows.UI.Xaml.Controls;
+using Windows.UI.Xaml.Controls.Primitives;
+using Windows.UI.Xaml.Data;
+using Windows.UI.Xaml.Input;
+using Windows.UI.Xaml.Media;
+using Windows.UI.Xaml.Navigation;
+
+namespace UWPClient
+{
+ ///
+ /// Provides application-specific behavior to supplement the default Application class.
+ ///
+ sealed partial class App : Application
+ {
+ ///
+ /// Initializes the singleton application object. This is the first line of authored code
+ /// executed, and as such is the logical equivalent of main() or WinMain().
+ ///
+ public App()
+ {
+ this.InitializeComponent();
+ this.Suspending += OnSuspending;
+ }
+
+ ///
+ /// Invoked when the application is launched normally by the end user. Other entry points
+ /// will be used such as when the application is launched to open a specific file.
+ ///
+ /// Details about the launch request and process.
+ protected override void OnLaunched(LaunchActivatedEventArgs e)
+ {
+ Frame rootFrame = Window.Current.Content as Frame;
+
+ // Do not repeat app initialization when the Window already has content,
+ // just ensure that the window is active
+ if (rootFrame == null)
+ {
+ // Create a Frame to act as the navigation context and navigate to the first page
+ rootFrame = new Frame();
+
+ rootFrame.NavigationFailed += OnNavigationFailed;
+
+ if (e.PreviousExecutionState == ApplicationExecutionState.Terminated)
+ {
+ //TODO: Load state from previously suspended application
+ }
+
+ // Place the frame in the current Window
+ Window.Current.Content = rootFrame;
+ }
+
+ if (e.PrelaunchActivated == false)
+ {
+ if (rootFrame.Content == null)
+ {
+ // When the navigation stack isn't restored navigate to the first page,
+ // configuring the new page by passing required information as a navigation
+ // parameter
+ rootFrame.Navigate(typeof(MainPage), e.Arguments);
+ }
+ // Ensure the current window is active
+ Window.Current.Activate();
+ }
+ }
+
+ ///
+ /// Invoked when Navigation to a certain page fails
+ ///
+ /// The Frame which failed navigation
+ /// Details about the navigation failure
+ void OnNavigationFailed(object sender, NavigationFailedEventArgs e)
+ {
+ throw new Exception("Failed to load Page " + e.SourcePageType.FullName);
+ }
+
+ ///
+ /// Invoked when application execution is being suspended. Application state is saved
+ /// without knowing whether the application will be terminated or resumed with the contents
+ /// of memory still intact.
+ ///
+ /// The source of the suspend request.
+ /// Details about the suspend request.
+ private void OnSuspending(object sender, SuspendingEventArgs e)
+ {
+ var deferral = e.SuspendingOperation.GetDeferral();
+ //TODO: Save application state and stop any background activity
+ deferral.Complete();
+ }
+ }
+}
diff --git a/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png
new file mode 100644
index 0000000..735f57a
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/LockScreenLogo.scale-200.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png b/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png
new file mode 100644
index 0000000..023e7f1
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/SplashScreen.scale-200.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png
new file mode 100644
index 0000000..af49fec
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square150x150Logo.scale-200.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png
new file mode 100644
index 0000000..ce342a2
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.scale-200.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png
new file mode 100644
index 0000000..f6c02ce
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Square44x44Logo.targetsize-24_altform-unplated.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/StoreLogo.png b/Tasks/Lab6/UWPClient/Assets/StoreLogo.png
new file mode 100644
index 0000000..7385b56
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/StoreLogo.png differ
diff --git a/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png b/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png
new file mode 100644
index 0000000..288995b
Binary files /dev/null and b/Tasks/Lab6/UWPClient/Assets/Wide310x150Logo.scale-200.png differ
diff --git a/Tasks/Lab6/UWPClient/MainPage.xaml b/Tasks/Lab6/UWPClient/MainPage.xaml
new file mode 100644
index 0000000..078c9af
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/MainPage.xaml
@@ -0,0 +1,27 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/Tasks/Lab6/UWPClient/MainPage.xaml.cs b/Tasks/Lab6/UWPClient/MainPage.xaml.cs
new file mode 100644
index 0000000..5f9ca08
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/MainPage.xaml.cs
@@ -0,0 +1,75 @@
+using System;
+using System.Collections.Generic;
+using System.IO;
+using System.Linq;
+using System.Net.Sockets;
+using System.Runtime.InteropServices.WindowsRuntime;
+using System.Text;
+using System.Threading.Tasks;
+using Windows.Foundation;
+using Windows.Foundation.Collections;
+using Windows.UI.Xaml;
+using Windows.UI.Xaml.Controls;
+using Windows.UI.Xaml.Controls.Primitives;
+using Windows.UI.Xaml.Data;
+using Windows.UI.Xaml.Input;
+using Windows.UI.Xaml.Media;
+using Windows.UI.Xaml.Navigation;
+
+// The Blank Page item template is documented at https://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409
+
+namespace UWPClient
+{
+ ///
+ /// An empty page that can be used on its own or navigated to within a Frame.
+ ///
+ public sealed partial class MainPage : Page
+ {
+ public MainPage()
+ {
+ InitializeComponent();
+ Received += AppendLine;
+ }
+
+ public event Action Received;
+
+ private void Button_Click(object sender, RoutedEventArgs e)
+ {
+ this.InvokeIfRequired(() => textBox.Text = "");
+ Task.Run(() => StartClient());
+ }
+
+ private void AppendLine(string line)
+ {
+ this.InvokeIfRequired(() => {
+ StringBuilder stringBuilder = new StringBuilder(textBox.Text);
+ stringBuilder.AppendLine(line);
+ textBox.Text = stringBuilder.ToString();
+ });
+ }
+
+ private void StartClient()
+ {
+ try
+ {
+ using (TcpClient client = new TcpClient("localhost", 8000))
+ using (Stream stream = client.GetStream())
+ using (StreamReader reader = new StreamReader(stream))
+ using (StreamWriter writer = new StreamWriter(stream))
+ {
+ string line;
+ writer.WriteLine();
+
+ while ((line = reader.ReadLine()) != null)
+ {
+ Received.Invoke(line);
+ }
+ }
+ }
+ catch (Exception e)
+ {
+ textBox.Text = e.ToString();
+ }
+ }
+ }
+}
diff --git a/Tasks/Lab6/UWPClient/Package.appxmanifest b/Tasks/Lab6/UWPClient/Package.appxmanifest
new file mode 100644
index 0000000..abd5858
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/Package.appxmanifest
@@ -0,0 +1,49 @@
+
+
+
+
+
+
+
+
+
+ UWPClient
+ Manuel
+ Assets\StoreLogo.png
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Tasks/Lab6/UWPClient/PageExtension.cs b/Tasks/Lab6/UWPClient/PageExtension.cs
new file mode 100644
index 0000000..57eeedc
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/PageExtension.cs
@@ -0,0 +1,13 @@
+using System;
+using Windows.UI.Xaml.Controls;
+
+namespace UWPClient
+{
+ public static class PageExtension
+ {
+ public static async void InvokeIfRequired(this Page page, Action action)
+ {
+ await page.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High, () => action());
+ }
+ }
+}
diff --git a/Tasks/Lab6/UWPClient/Properties/AssemblyInfo.cs b/Tasks/Lab6/UWPClient/Properties/AssemblyInfo.cs
new file mode 100644
index 0000000..73475bf
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/Properties/AssemblyInfo.cs
@@ -0,0 +1,29 @@
+using System.Reflection;
+using System.Runtime.CompilerServices;
+using System.Runtime.InteropServices;
+
+// General Information about an assembly is controlled through the following
+// set of attributes. Change these attribute values to modify the information
+// associated with an assembly.
+[assembly: AssemblyTitle("UWPClient")]
+[assembly: AssemblyDescription("")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("")]
+[assembly: AssemblyProduct("UWPClient")]
+[assembly: AssemblyCopyright("Copyright © 2024")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// Version information for an assembly consists of the following four values:
+//
+// Major Version
+// Minor Version
+// Build Number
+// Revision
+//
+// You can specify all the values or you can default the Build and Revision Numbers
+// by using the '*' as shown below:
+// [assembly: AssemblyVersion("1.0.*")]
+[assembly: AssemblyVersion("1.0.0.0")]
+[assembly: AssemblyFileVersion("1.0.0.0")]
+[assembly: ComVisible(false)]
\ No newline at end of file
diff --git a/Tasks/Lab6/UWPClient/Properties/Default.rd.xml b/Tasks/Lab6/UWPClient/Properties/Default.rd.xml
new file mode 100644
index 0000000..af00722
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/Properties/Default.rd.xml
@@ -0,0 +1,31 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Tasks/Lab6/UWPClient/UWPClient.csproj b/Tasks/Lab6/UWPClient/UWPClient.csproj
new file mode 100644
index 0000000..a469adf
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/UWPClient.csproj
@@ -0,0 +1,169 @@
+
+
+
+
+ Debug
+ x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}
+ AppContainerExe
+ Properties
+ UWPClient
+ UWPClient
+ en-US
+ UAP
+ 10.0.19041.0
+ 10.0.17763.0
+ 14
+ 512
+ {A5A43C5B-DE2A-4C0C-9213-0A381AF9435A};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}
+ true
+ false
+
+
+ true
+ bin\x86\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ x86
+ false
+ prompt
+ true
+
+
+ bin\x86\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ x86
+ false
+ prompt
+ true
+ true
+
+
+ true
+ bin\ARM\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ ARM
+ false
+ prompt
+ true
+
+
+ bin\ARM\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ ARM
+ false
+ prompt
+ true
+ true
+
+
+ true
+ bin\ARM64\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ ARM64
+ false
+ prompt
+ true
+ true
+
+
+ bin\ARM64\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ ARM64
+ false
+ prompt
+ true
+ true
+
+
+ true
+ bin\x64\Debug\
+ DEBUG;TRACE;NETFX_CORE;WINDOWS_UWP
+ ;2008
+ full
+ x64
+ false
+ prompt
+ true
+
+
+ bin\x64\Release\
+ TRACE;NETFX_CORE;WINDOWS_UWP
+ true
+ ;2008
+ pdbonly
+ x64
+ false
+ prompt
+ true
+ true
+
+
+ PackageReference
+
+
+
+ App.xaml
+
+
+ MainPage.xaml
+
+
+
+
+
+
+ Designer
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ MSBuild:Compile
+ Designer
+
+
+ MSBuild:Compile
+ Designer
+
+
+
+
+ 6.2.12
+
+
+
+ 14.0
+
+
+
+
\ No newline at end of file
diff --git a/Tasks/Lab6/UWPClient/UWPClient.sln b/Tasks/Lab6/UWPClient/UWPClient.sln
new file mode 100644
index 0000000..026833c
--- /dev/null
+++ b/Tasks/Lab6/UWPClient/UWPClient.sln
@@ -0,0 +1,51 @@
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio Version 16
+VisualStudioVersion = 16.0.34902.97
+MinimumVisualStudioVersion = 10.0.40219.1
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "UWPClient", "UWPClient.csproj", "{D7CF1F46-74E2-48E1-A43C-4288A98F0193}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|ARM = Debug|ARM
+ Debug|ARM64 = Debug|ARM64
+ Debug|x64 = Debug|x64
+ Debug|x86 = Debug|x86
+ Release|ARM = Release|ARM
+ Release|ARM64 = Release|ARM64
+ Release|x64 = Release|x64
+ Release|x86 = Release|x86
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM.ActiveCfg = Debug|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM.Build.0 = Debug|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM.Deploy.0 = Debug|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM64.ActiveCfg = Debug|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM64.Build.0 = Debug|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|ARM64.Deploy.0 = Debug|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x64.ActiveCfg = Debug|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x64.Build.0 = Debug|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x64.Deploy.0 = Debug|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x86.ActiveCfg = Debug|x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x86.Build.0 = Debug|x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Debug|x86.Deploy.0 = Debug|x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM.ActiveCfg = Release|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM.Build.0 = Release|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM.Deploy.0 = Release|ARM
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM64.ActiveCfg = Release|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM64.Build.0 = Release|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|ARM64.Deploy.0 = Release|ARM64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x64.ActiveCfg = Release|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x64.Build.0 = Release|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x64.Deploy.0 = Release|x64
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x86.ActiveCfg = Release|x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x86.Build.0 = Release|x86
+ {D7CF1F46-74E2-48E1-A43C-4288A98F0193}.Release|x86.Deploy.0 = Release|x86
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {6924C1B2-1829-4014-A03E-DFD4F95CFDA6}
+ EndGlobalSection
+EndGlobal