Added some styles for evaluation result and tried to solve sync problems
This commit is contained in:
parent
961a2a7666
commit
5f0712c799
@ -24,14 +24,17 @@
|
|||||||
<None Remove="Resources\arrow_up_blue.png" />
|
<None Remove="Resources\arrow_up_blue.png" />
|
||||||
<None Remove="Resources\arrow_up_green.png" />
|
<None Remove="Resources\arrow_up_green.png" />
|
||||||
<None Remove="Resources\arrow_up_red.png" />
|
<None Remove="Resources\arrow_up_red.png" />
|
||||||
|
<None Remove="Resources\check.png" />
|
||||||
<None Remove="Resources\clipboard.png" />
|
<None Remove="Resources\clipboard.png" />
|
||||||
<None Remove="Resources\clock.png" />
|
<None Remove="Resources\clock.png" />
|
||||||
<None Remove="Resources\containership.ico" />
|
<None Remove="Resources\containership.ico" />
|
||||||
<None Remove="Resources\containership.png" />
|
<None Remove="Resources\containership.png" />
|
||||||
<None Remove="Resources\delete.png" />
|
<None Remove="Resources\delete.png" />
|
||||||
|
<None Remove="Resources\delete2.png" />
|
||||||
<None Remove="Resources\emergency_stop_button.png" />
|
<None Remove="Resources\emergency_stop_button.png" />
|
||||||
<None Remove="Resources\logo_bremen_calling.png" />
|
<None Remove="Resources\logo_bremen_calling.png" />
|
||||||
<None Remove="Resources\ship2.png" />
|
<None Remove="Resources\ship2.png" />
|
||||||
|
<None Remove="Resources\sign_warning.png" />
|
||||||
<None Remove="Resources\trafficlight_green.png" />
|
<None Remove="Resources\trafficlight_green.png" />
|
||||||
<None Remove="Resources\trafficlight_off.png" />
|
<None Remove="Resources\trafficlight_off.png" />
|
||||||
<None Remove="Resources\trafficlight_on.png" />
|
<None Remove="Resources\trafficlight_on.png" />
|
||||||
@ -72,14 +75,17 @@
|
|||||||
<Resource Include="Resources\arrow_up_blue.png" />
|
<Resource Include="Resources\arrow_up_blue.png" />
|
||||||
<Resource Include="Resources\arrow_up_green.png" />
|
<Resource Include="Resources\arrow_up_green.png" />
|
||||||
<Resource Include="Resources\arrow_up_red.png" />
|
<Resource Include="Resources\arrow_up_red.png" />
|
||||||
|
<Resource Include="Resources\check.png" />
|
||||||
<Resource Include="Resources\clipboard.png" />
|
<Resource Include="Resources\clipboard.png" />
|
||||||
<Resource Include="Resources\clock.png" />
|
<Resource Include="Resources\clock.png" />
|
||||||
<Resource Include="Resources\containership.ico" />
|
<Resource Include="Resources\containership.ico" />
|
||||||
<Resource Include="Resources\containership.png" />
|
<Resource Include="Resources\containership.png" />
|
||||||
<Resource Include="Resources\delete.png" />
|
<Resource Include="Resources\delete.png" />
|
||||||
|
<Resource Include="Resources\delete2.png" />
|
||||||
<Resource Include="Resources\emergency_stop_button.png" />
|
<Resource Include="Resources\emergency_stop_button.png" />
|
||||||
<Resource Include="Resources\logo_bremen_calling.png" />
|
<Resource Include="Resources\logo_bremen_calling.png" />
|
||||||
<Resource Include="Resources\ship2.png" />
|
<Resource Include="Resources\ship2.png" />
|
||||||
|
<Resource Include="Resources\sign_warning.png" />
|
||||||
<Resource Include="Resources\StringResources.de.xaml">
|
<Resource Include="Resources\StringResources.de.xaml">
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Resource>
|
</Resource>
|
||||||
|
|||||||
@ -16,7 +16,7 @@ using BreCalClient.misc.Client;
|
|||||||
using BreCalClient.misc.Model;
|
using BreCalClient.misc.Model;
|
||||||
|
|
||||||
using static BreCalClient.Extensions;
|
using static BreCalClient.Extensions;
|
||||||
using System.Runtime.Serialization;
|
using System.Collections.Concurrent;
|
||||||
|
|
||||||
namespace BreCalClient
|
namespace BreCalClient
|
||||||
{
|
{
|
||||||
@ -31,11 +31,13 @@ namespace BreCalClient
|
|||||||
|
|
||||||
#region Fields
|
#region Fields
|
||||||
|
|
||||||
|
private static Int32 _uiUpdateRunning = 0;
|
||||||
|
|
||||||
private Timer? _timer;
|
private Timer? _timer;
|
||||||
private Credentials? _credentials;
|
private Credentials? _credentials;
|
||||||
|
|
||||||
private readonly Dictionary<int, ShipcallControlModel> _allShipcallsDict = new();
|
private readonly ConcurrentDictionary<int, ShipcallControlModel> _allShipcallsDict = new();
|
||||||
private readonly Dictionary<int, ShipcallControl> _allShipCallsControlDict = new();
|
private readonly ConcurrentDictionary<int, ShipcallControl> _allShipCallsControlDict = new();
|
||||||
private readonly List<ShipcallControlModel> _visibleControlModels = new();
|
private readonly List<ShipcallControlModel> _visibleControlModels = new();
|
||||||
|
|
||||||
private readonly DefaultApi _api;
|
private readonly DefaultApi _api;
|
||||||
@ -412,8 +414,8 @@ namespace BreCalClient
|
|||||||
ShipcallControlModel removeModel = this._allShipcallsDict[shipcallId];
|
ShipcallControlModel removeModel = this._allShipcallsDict[shipcallId];
|
||||||
_visibleControlModels.Remove(removeModel);
|
_visibleControlModels.Remove(removeModel);
|
||||||
|
|
||||||
this._allShipCallsControlDict.Remove(shipcallId);
|
this._allShipCallsControlDict.Remove(shipcallId, out _);
|
||||||
this._allShipcallsDict.Remove(shipcallId);
|
this._allShipcallsDict.Remove(shipcallId, out _);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void FilterShipcalls()
|
private void FilterShipcalls()
|
||||||
@ -513,6 +515,10 @@ namespace BreCalClient
|
|||||||
{
|
{
|
||||||
|
|
||||||
this.Dispatcher.Invoke(new Action(() =>
|
this.Dispatcher.Invoke(new Action(() =>
|
||||||
|
{
|
||||||
|
if (Interlocked.CompareExchange(ref _uiUpdateRunning, 1, 0) == 1) return;
|
||||||
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
this.stackPanel.Children.Clear();
|
this.stackPanel.Children.Clear();
|
||||||
foreach (ShipcallControlModel visibleModel in this._visibleControlModels)
|
foreach (ShipcallControlModel visibleModel in this._visibleControlModels)
|
||||||
@ -524,6 +530,15 @@ namespace BreCalClient
|
|||||||
this.stackPanel.Children.Add(this._allShipCallsControlDict[visibleModel.Shipcall.Id]);
|
this.stackPanel.Children.Add(this._allShipCallsControlDict[visibleModel.Shipcall.Id]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
catch(Exception e) {
|
||||||
|
_log.ErrorFormat("Exception running ui update: {0}", e.ToString());
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
_uiUpdateRunning = 0;
|
||||||
|
}
|
||||||
|
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
30
src/BreCalClient/Resources/Resources.Designer.cs
generated
30
src/BreCalClient/Resources/Resources.Designer.cs
generated
@ -110,6 +110,16 @@ namespace BreCalClient.Resources {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized resource of type System.Byte[].
|
||||||
|
/// </summary>
|
||||||
|
public static byte[] check {
|
||||||
|
get {
|
||||||
|
object obj = ResourceManager.GetObject("check", resourceCulture);
|
||||||
|
return ((byte[])(obj));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized resource of type System.Byte[].
|
/// Looks up a localized resource of type System.Byte[].
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -160,6 +170,16 @@ namespace BreCalClient.Resources {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized resource of type System.Byte[].
|
||||||
|
/// </summary>
|
||||||
|
public static byte[] delete2 {
|
||||||
|
get {
|
||||||
|
object obj = ResourceManager.GetObject("delete2", resourceCulture);
|
||||||
|
return ((byte[])(obj));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized resource of type System.Byte[].
|
/// Looks up a localized resource of type System.Byte[].
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -190,6 +210,16 @@ namespace BreCalClient.Resources {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Looks up a localized resource of type System.Byte[].
|
||||||
|
/// </summary>
|
||||||
|
public static byte[] sign_warning {
|
||||||
|
get {
|
||||||
|
object obj = ResourceManager.GetObject("sign_warning", resourceCulture);
|
||||||
|
return ((byte[])(obj));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Looks up a localized string similar to Agencies.
|
/// Looks up a localized string similar to Agencies.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@ -133,6 +133,9 @@
|
|||||||
<data name="arrow_up_red" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<data name="arrow_up_red" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
<value>arrow_up_red.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
<value>arrow_up_red.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="check" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
|
<value>check.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</data>
|
||||||
<data name="clipboard" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<data name="clipboard" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
<value>clipboard.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
<value>clipboard.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
</data>
|
</data>
|
||||||
@ -148,6 +151,9 @@
|
|||||||
<data name="delete" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<data name="delete" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
<value>delete.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
<value>delete.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="delete2" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
|
<value>delete2.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</data>
|
||||||
<data name="emergency_stop_button" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<data name="emergency_stop_button" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
<value>emergency_stop_button.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
<value>emergency_stop_button.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
</data>
|
</data>
|
||||||
@ -157,6 +163,9 @@
|
|||||||
<data name="ship2" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
<data name="ship2" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
<value>ship2.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
<value>ship2.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
</data>
|
</data>
|
||||||
|
<data name="sign_warning" type="System.Resources.ResXFileRef, System.Windows.Forms">
|
||||||
|
<value>sign_warning.png;System.Byte[], mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</value>
|
||||||
|
</data>
|
||||||
<data name="textAgencies" xml:space="preserve">
|
<data name="textAgencies" xml:space="preserve">
|
||||||
<value>Agencies</value>
|
<value>Agencies</value>
|
||||||
</data>
|
</data>
|
||||||
|
|||||||
BIN
src/BreCalClient/Resources/check.png
Normal file
BIN
src/BreCalClient/Resources/check.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
BIN
src/BreCalClient/Resources/delete2.png
Normal file
BIN
src/BreCalClient/Resources/delete2.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.7 KiB |
BIN
src/BreCalClient/Resources/sign_warning.png
Normal file
BIN
src/BreCalClient/Resources/sign_warning.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.3 KiB |
@ -3,17 +3,15 @@
|
|||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
xmlns:local="clr-namespace:BreCalClient"
|
|
||||||
xmlns:p = "clr-namespace:BreCalClient.Resources"
|
xmlns:p = "clr-namespace:BreCalClient.Resources"
|
||||||
xmlns:sets="clr-namespace:BreCalClient.Properties"
|
xmlns:sets="clr-namespace:BreCalClient.Properties"
|
||||||
xmlns:db="clr-namespace:BreCalClient;assembly=BreCalClient"
|
xmlns:db="clr-namespace:BreCalClient;assembly=BreCalTestClient"
|
||||||
xmlns:db2="clr-namespace:BreCalClient.misc.Model;assembly=BreCalClient"
|
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
d:DesignHeight="120" d:DesignWidth="800" Loaded="UserControl_Loaded">
|
d:DesignHeight="120" d:DesignWidth="800" Loaded="UserControl_Loaded">
|
||||||
<Border BorderBrush="LightGray" Margin="1" BorderThickness="1">
|
<Border BorderBrush="LightGray" Margin="1" BorderThickness="1">
|
||||||
<Grid>
|
<Grid>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width=".1*" />
|
<ColumnDefinition Width=".13*" />
|
||||||
<ColumnDefinition Width=".15*" />
|
<ColumnDefinition Width=".15*" />
|
||||||
<ColumnDefinition Width=".15*" />
|
<ColumnDefinition Width=".15*" />
|
||||||
<ColumnDefinition Width=".15*" />
|
<ColumnDefinition Width=".15*" />
|
||||||
@ -40,14 +38,35 @@
|
|||||||
<ColumnDefinition Width=".4*" />
|
<ColumnDefinition Width=".4*" />
|
||||||
<ColumnDefinition Width=".6*" />
|
<ColumnDefinition Width=".6*" />
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Grid Grid.Row="0" Grid.Column="0" Grid.RowSpan="1" Grid.ColumnSpan="2">
|
<Grid Grid.Row="0" Grid.Column="0" Grid.RowSpan="1" Grid.ColumnSpan="3">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="30" />
|
<ColumnDefinition Width="30" />
|
||||||
<ColumnDefinition Width="*" />
|
<ColumnDefinition Width="*" />
|
||||||
|
<ColumnDefinition Width="32" />
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Image Margin="2" Grid.Column="0" PreviewMouseUp="Image_PreviewMouseUp" x:Name="imageShipcallType" />
|
<Image Margin="2" Grid.Column="0" PreviewMouseUp="Image_PreviewMouseUp" x:Name="imageShipcallType" />
|
||||||
<Label Grid.Column="1" FontSize="12" x:Name="labelShipName" Foreground="White" Background="{Binding Source={x:Static sets:Settings.Default}, Path=BG_COLOR}" VerticalAlignment="Stretch"
|
<Label Grid.Column="1" FontSize="12" x:Name="labelShipName" Foreground="White" Background="{Binding Source={x:Static sets:Settings.Default}, Path=BG_COLOR}" VerticalAlignment="Stretch"
|
||||||
HorizontalAlignment="Stretch" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" PreviewMouseUp="Image_PreviewMouseUp"/>
|
HorizontalAlignment="Stretch" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" PreviewMouseUp="Image_PreviewMouseUp"/>
|
||||||
|
<Grid Grid.Column="2" Background="{Binding Source={x:Static sets:Settings.Default}, Path=BG_COLOR}">
|
||||||
|
<Image Grid.Column="3" Margin="2" x:Name="imageEvaluation">
|
||||||
|
<Image.Style>
|
||||||
|
<Style TargetType="Image">
|
||||||
|
<Setter Property="Source" Value="{Binding NotFolderImage}"/>
|
||||||
|
<Style.Triggers>
|
||||||
|
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.GREEN}">
|
||||||
|
<Setter Property="Source" Value="./Resources/check.png"/>
|
||||||
|
</DataTrigger>
|
||||||
|
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.RED}">
|
||||||
|
<Setter Property="Source" Value="./Resources/delete2.png"/>
|
||||||
|
</DataTrigger>
|
||||||
|
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.YELLOW}">
|
||||||
|
<Setter Property="Source" Value="./Resources/sign_warning.png"/>
|
||||||
|
</DataTrigger>
|
||||||
|
</Style.Triggers>
|
||||||
|
</Style>
|
||||||
|
</Image.Style>
|
||||||
|
</Image>
|
||||||
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
<Viewbox Grid.Row="1" Grid.Column="0" HorizontalAlignment="Left">
|
<Viewbox Grid.Row="1" Grid.Column="0" HorizontalAlignment="Left">
|
||||||
<TextBlock Text="IMO" />
|
<TextBlock Text="IMO" />
|
||||||
@ -211,34 +230,6 @@
|
|||||||
<TextBlock Grid.Row="3" Grid.Column="1" Padding="0" TextWrapping="Wrap" VerticalAlignment="Top" x:Name="textBlockTerminalBerthRemarks" FontSize="10"/>
|
<TextBlock Grid.Row="3" Grid.Column="1" Padding="0" TextWrapping="Wrap" VerticalAlignment="Top" x:Name="textBlockTerminalBerthRemarks" FontSize="10"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Border>
|
</Border>
|
||||||
|
|
||||||
<!-- Image Margin="2" Grid.Column="3" Grid.Row="0" Grid.RowSpan="3">
|
|
||||||
<Image.Style>
|
|
||||||
<Style TargetType="Image">
|
|
||||||
<Setter Property="Source" Value="{Binding NotFolderImage}"/>
|
|
||||||
<Style.Triggers>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.OFF}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_off.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.RED}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_red.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.RED_YELLOW}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_red_yellow.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.GREEN}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_green.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.ALL}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_on.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
<DataTrigger Binding="{Binding LightMode}" Value="{x:Static db:ShipcallControlModel+TrafficLightMode.YELLOW}">
|
|
||||||
<Setter Property="Source" Value="./Resources/trafficlight_yellow.png"/>
|
|
||||||
</DataTrigger>
|
|
||||||
</Style.Triggers>
|
|
||||||
</Style>
|
|
||||||
</Image.Style>
|
|
||||||
</Image-->
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</Border>
|
</Border>
|
||||||
</UserControl>
|
</UserControl>
|
||||||
|
|||||||
@ -3,13 +3,13 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
using BreCalClient.misc.Model;
|
using BreCalClient.misc.Model;
|
||||||
|
using log4net;
|
||||||
using System;
|
using System;
|
||||||
using System.Windows;
|
using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
using System.Windows.Media.Imaging;
|
using System.Windows.Media.Imaging;
|
||||||
|
|
||||||
|
|
||||||
namespace BreCalClient
|
namespace BreCalClient
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -25,6 +25,7 @@ namespace BreCalClient
|
|||||||
Participant? _terminal;
|
Participant? _terminal;
|
||||||
Participant? _tug;
|
Participant? _tug;
|
||||||
Participant? _port_administration;
|
Participant? _port_administration;
|
||||||
|
private static readonly ILog _log = LogManager.GetLogger(typeof(ShipcallControl));
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
@ -59,6 +60,8 @@ namespace BreCalClient
|
|||||||
#region public methods
|
#region public methods
|
||||||
|
|
||||||
public void RefreshData()
|
public void RefreshData()
|
||||||
|
{
|
||||||
|
try
|
||||||
{
|
{
|
||||||
if (this.ShipcallControlModel != null)
|
if (this.ShipcallControlModel != null)
|
||||||
{
|
{
|
||||||
@ -148,6 +151,29 @@ namespace BreCalClient
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this.ShipcallControlModel?.Shipcall?.Evaluation != null)
|
||||||
|
{
|
||||||
|
ShipcallControlModel.TrafficLightMode resultColor = (ShipcallControlModel.TrafficLightMode) (this.ShipcallControlModel?.Shipcall?.Evaluation ?? 0); // der nullable Operator hier ist so doof, die VS validation blickts einfach nicht
|
||||||
|
switch (resultColor)
|
||||||
|
{
|
||||||
|
case ShipcallControlModel.TrafficLightMode.GREEN:
|
||||||
|
this.Background = Brushes.LightGreen;
|
||||||
|
break;
|
||||||
|
case ShipcallControlModel.TrafficLightMode.YELLOW:
|
||||||
|
this.Background= Brushes.LightYellow;
|
||||||
|
break;
|
||||||
|
case ShipcallControlModel.TrafficLightMode.RED:
|
||||||
|
this.Background = new SolidColorBrush(Color.FromArgb(200, 255, 100, 100));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
this.Background = Brushes.Transparent;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(this.ShipcallControlModel?.Shipcall?.EvaluationMessage))
|
||||||
|
this.imageEvaluation.ToolTip = this.ShipcallControlModel?.Shipcall?.EvaluationMessage;
|
||||||
|
|
||||||
this.textBlockBerth.Text = this.ShipcallControlModel?.Berth;
|
this.textBlockBerth.Text = this.ShipcallControlModel?.Berth;
|
||||||
this.textBlockCallsign.Text = this.ShipcallControlModel?.Ship?.Callsign;
|
this.textBlockCallsign.Text = this.ShipcallControlModel?.Ship?.Callsign;
|
||||||
if ((this.ShipcallControlModel?.Shipcall?.Type == 1) || (this.ShipcallControlModel?.Shipcall?.Type == 3))
|
if ((this.ShipcallControlModel?.Shipcall?.Type == 1) || (this.ShipcallControlModel?.Shipcall?.Type == 3))
|
||||||
@ -176,6 +202,8 @@ namespace BreCalClient
|
|||||||
this.labelETAETDTerminal.Content = BreCalClient.Resources.Resources.textOperationsEnd;
|
this.labelETAETDTerminal.Content = BreCalClient.Resources.Resources.textOperationsEnd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this.ShipcallControlModel != null)
|
||||||
|
{
|
||||||
foreach (Times times in this.ShipcallControlModel.Times)
|
foreach (Times times in this.ShipcallControlModel.Times)
|
||||||
{
|
{
|
||||||
string? berthText = null;
|
string? berthText = null;
|
||||||
@ -262,6 +290,13 @@ namespace BreCalClient
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
this.DataContext = this.ShipcallControlModel;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
_log.ErrorFormat("Something went wrong during data refresh: {0}", ex.ToString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|||||||
@ -55,23 +55,16 @@ namespace BreCalClient
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (IsFlagSet(StatusFlags.RED))
|
TrafficLightMode tlm = TrafficLightMode.OFF;
|
||||||
|
|
||||||
|
if (this.Shipcall != null)
|
||||||
{
|
{
|
||||||
if (IsFlagSet((StatusFlags)StatusFlags.YELLOW))
|
if(this.Shipcall.Evaluation.HasValue)
|
||||||
{
|
{
|
||||||
if (IsFlagSet(StatusFlags.GREEN))
|
tlm = (TrafficLightMode)this.Shipcall.Evaluation;
|
||||||
{
|
|
||||||
return TrafficLightMode.ALL;
|
|
||||||
}
|
}
|
||||||
return TrafficLightMode.RED_YELLOW;
|
|
||||||
}
|
}
|
||||||
return TrafficLightMode.RED;
|
return tlm;
|
||||||
}
|
|
||||||
if (IsFlagSet(StatusFlags.YELLOW))
|
|
||||||
return TrafficLightMode.YELLOW;
|
|
||||||
if (IsFlagSet(StatusFlags.GREEN))
|
|
||||||
return TrafficLightMode.GREEN;
|
|
||||||
return TrafficLightMode.OFF;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user