1
0
mirror of synced 2025-01-22 16:13:08 +01:00

Added Autoscroll and Clear functionality, missing MessageBodyRenderer and fixed ReSharper code issues

This commit is contained in:
PsychoMark 2016-06-20 14:20:37 +02:00
parent e6fa2ee1d9
commit 7785b6a0ed
14 changed files with 77 additions and 32 deletions

View File

@ -7,7 +7,7 @@ using SimpleInjector;
namespace PettingZoo
{
public partial class App : Application
public partial class App
{
public void ApplicationStartup(object sender, StartupEventArgs e)
{
@ -25,7 +25,7 @@ namespace PettingZoo
// Automatically register all Window and BaseViewModel descendants
foreach (var type in Assembly.GetExecutingAssembly().GetExportedTypes()
.Where(t => t.IsSubclassOf(typeof(System.Windows.Window)) ||
.Where(t => t.IsSubclassOf(typeof(Window)) ||
t.IsSubclassOf(typeof(Infrastructure.BaseViewModel))))
{
container.Register(type);

View File

@ -58,7 +58,7 @@ namespace PettingZoo.Infrastructure
}
foreach (UIElement element in InternalChildren)
{
FrameworkElement fe = element as FrameworkElement;
var fe = element as FrameworkElement;
if (null != fe)
{
int row = GetRow(fe);

View File

@ -20,11 +20,11 @@ namespace PettingZoo.Infrastructure
private static void OnBoundPasswordChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
PasswordBox box = d as PasswordBox;
var box = d as PasswordBox;
// only handle this event when the property is attached to a PasswordBox
// and when the BindPassword attached property has been set to true
if (d == null || !GetBindPassword(d))
if (box == null || !GetBindPassword(d))
{
return;
}
@ -32,7 +32,7 @@ namespace PettingZoo.Infrastructure
// avoid recursive updating by ignoring the box's changed event
box.PasswordChanged -= HandlePasswordChanged;
string newPassword = (string) e.NewValue;
var newPassword = (string) e.NewValue;
if (!GetUpdatingPassword(box))
{
@ -47,15 +47,15 @@ namespace PettingZoo.Infrastructure
// when the BindPassword attached property is set on a PasswordBox,
// start listening to its PasswordChanged event
PasswordBox box = dp as PasswordBox;
var box = dp as PasswordBox;
if (box == null)
{
return;
}
bool wasBound = (bool) (e.OldValue);
bool needToBind = (bool) (e.NewValue);
var wasBound = (bool) (e.OldValue);
var needToBind = (bool) (e.NewValue);
if (wasBound)
{
@ -70,7 +70,9 @@ namespace PettingZoo.Infrastructure
private static void HandlePasswordChanged(object sender, RoutedEventArgs e)
{
PasswordBox box = sender as PasswordBox;
var box = sender as PasswordBox;
if (box == null)
return;
// set a flag to indicate that we're updating the password
SetUpdatingPassword(box, true);

View File

@ -14,7 +14,7 @@
public static ConnectionInfo Default()
{
return new ConnectionInfo()
return new ConnectionInfo
{
Host = "localhost",
Port = 5672,

View File

@ -0,0 +1,27 @@
using System;
using System.Collections.Generic;
using System.Text;
namespace PettingZoo.Model
{
public class MessageBodyRenderer
{
public static List<String> TextTypes = new List<string>
{
"application/json",
"application/xml"
};
public static string Render(byte[] body, string contentType = "")
{
if (TextTypes.Contains(contentType))
{
return Encoding.UTF8.GetString(body);
}
// ToDo hex output
return "";
}
}
}

View File

@ -1,9 +1,11 @@
using System.Collections.Generic;
using System;
using System.Collections.Generic;
namespace PettingZoo.Model
{
public class MessageInfo
{
public DateTime Timestamp { get; set; }
public string RoutingKey { get; set; }
public byte[] Body { get; set; }
@ -18,5 +20,11 @@ namespace PettingZoo.Model
: "";
}
}
public MessageInfo()
{
Timestamp = DateTime.Now;
}
}
}

View File

@ -23,7 +23,7 @@ namespace PettingZoo.Model
break;
if (MessageReceived != null)
MessageReceived(null, new MessageReceivedEventArgs(new MessageInfo()
MessageReceived(null, new MessageReceivedEventArgs(new MessageInfo
{
RoutingKey = "test",
Body = Encoding.UTF8.GetBytes("{ \"hello\": \"world\" }"),
@ -33,7 +33,7 @@ namespace PettingZoo.Model
{ "classType", "LEF.Messaging.Internal.ActieNewMessage" }
}
}));
Thread.Sleep(1000);
Thread.Sleep(200);
}
}, token);
}

View File

@ -100,6 +100,7 @@
<Compile Include="Infrastructure\DelegateCommand.cs" />
<Compile Include="Infrastructure\BaseViewModel.cs" />
<Compile Include="Infrastructure\GridLayout.cs" />
<Compile Include="Infrastructure\ListBoxAutoScroll.cs" />
<Compile Include="Infrastructure\PasswordBoxAssistant.cs" />
<Compile Include="Model\IConnection.cs" />
<Compile Include="Model\IConnectionFactory.cs" />

View File

@ -1,6 +1,4 @@
using System.Reflection;
using System.Resources;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Windows;

View File

@ -25,7 +25,7 @@ namespace PettingZoo.View
}
public partial class ConnectionWindow : Window
public partial class ConnectionWindow
{
public ConnectionWindow(ConnectionViewModel viewModel)
{

View File

@ -5,6 +5,7 @@
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:viewModel="clr-namespace:PettingZoo.ViewModel"
xmlns:infrastructure="clr-namespace:PettingZoo.Infrastructure"
mc:Ignorable="d"
d:DataContext="{d:DesignInstance viewModel:MainViewModel}"
Width="800"
@ -28,16 +29,22 @@
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="300" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<ListBox Grid.Column="0" Grid.Row="0"
HorizontalAlignment="Stretch"
ItemsSource="{Binding Messages}"
SelectedItem="{Binding Path=SelectedMessage, Mode=TwoWay}">
SelectedItem="{Binding Path=SelectedMessage, Mode=TwoWay}"
infrastructure:ListBox.AutoScroll="True">
<ListBox.ItemTemplate>
<DataTemplate>
<Grid>
<TextBlock Text="{Binding RoutingKey}"></TextBlock>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" MinWidth="150"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<TextBlock Grid.Column="0" Grid.Row="0" Text="{Binding Timestamp}"></TextBlock>
<TextBlock Grid.Column="1" Grid.Row="0" Text="{Binding RoutingKey}"></TextBlock>
</Grid>
</DataTemplate>
</ListBox.ItemTemplate>

View File

@ -1,13 +1,9 @@
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Controls.Primitives;
using System.Windows.Data;
using System.Windows;
using PettingZoo.ViewModel;
namespace PettingZoo.View
{
public partial class MainWindow : Window
public partial class MainWindow
{
public MainWindow(MainViewModel viewModel)
{

View File

@ -8,7 +8,7 @@ namespace PettingZoo.ViewModel
{
public class ConnectionViewModel
{
private static IMapper modelMapper = new MapperConfiguration(cfg =>
private static readonly IMapper ModelMapper = new MapperConfiguration(cfg =>
{
cfg.CreateMap<ConnectionInfo, ConnectionViewModel>();
cfg.CreateMap<ConnectionViewModel, ConnectionInfo>();
@ -41,13 +41,13 @@ namespace PettingZoo.ViewModel
public ConnectionViewModel(ConnectionInfo model) : this()
{
modelMapper.Map(model, this);
ModelMapper.Map(model, this);
}
public ConnectionInfo ToModel()
{
return modelMapper.Map<ConnectionInfo>(this);
return ModelMapper.Map<ConnectionInfo>(this);
}

View File

@ -124,24 +124,30 @@ namespace PettingZoo.ViewModel
private void ClearExecute()
{
messages.Clear();
clearCommand.RaiseCanExecuteChanged();
}
private bool ClearCanExecute()
{
return false;
return messages.Count > 0;
}
private void ConnectionMessageReceived(object sender, MessageReceivedEventArgs e)
{
RunFromUiScheduler(() => messages.Add(e.MessageInfo));
RunFromUiScheduler(() =>
{
messages.Add(e.MessageInfo);
clearCommand.RaiseCanExecuteChanged();
});
}
private void RunFromUiScheduler(Action action)
{
Task.Factory.StartNew(action, CancellationToken.None, TaskCreationOptions.None, uiScheduler);
Task.Factory.StartNew(action, CancellationToken.None, TaskCreationOptions.None, uiScheduler);
}
}
}