BackUpCompareView.xaml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <UserControl
  2. x:Class="FurnaceUI.Views.Parameter.BackUpCompareView"
  3. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  4. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  5. xmlns:cal="http://www.caliburn.org"
  6. xmlns:converter1="clr-namespace:Aitex.Core.UI.Converters;assembly=MECF.Framework.UI.Core"
  7. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  8. xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"
  9. xmlns:local="clr-namespace:FurnaceUI.Views.Parameter"
  10. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  11. xmlns:systemConfig="clr-namespace:MECF.Framework.UI.Client.CenterViews.Configs.SystemConfig;assembly=MECF.Framework.UI.Client"
  12. xmlns:usercontrols="clr-namespace:MECF.Framework.UI.Client.ClientBase.UserControls;assembly=MECF.Framework.UI.Client"
  13. d:DesignHeight="700"
  14. d:DesignWidth="1000"
  15. mc:Ignorable="d">
  16. <UserControl.Resources>
  17. <Style BasedOn="{StaticResource ExOnlyVerticalScrollBar}" TargetType="ScrollBar"/>
  18. <converter1:Bool2CollapsedReverseConverter x:Key="Bool2CollapsedReverseConverter"/>
  19. <HierarchicalDataTemplate
  20. x:Key="ConfigNodeTemplate"
  21. DataType="{x:Type systemConfig:ConfigNode}"
  22. ItemsSource="{Binding SubNodes}">
  23. <TextBlock
  24. Margin="0,5,0,5"
  25. VerticalAlignment="Center"
  26. FontSize="18"
  27. Text="{Binding Display}"/>
  28. </HierarchicalDataTemplate>
  29. <converter1:BoolToBoolReverseConverter x:Key="BoolToBoolReverseConverter"/>
  30. </UserControl.Resources>
  31. <Grid IsEnabled="{Binding BusyIndicatorVisibility, UpdateSourceTrigger=PropertyChanged, Converter={StaticResource BoolToBoolReverseConverter}}">
  32. <Grid.ColumnDefinitions>
  33. <ColumnDefinition Width="280"/>
  34. <ColumnDefinition Width="948"/>
  35. </Grid.ColumnDefinitions>
  36. <TreeView
  37. x:Name="PART_TREE"
  38. Height="700"
  39. ItemTemplate="{StaticResource ConfigNodeTemplate}"
  40. ItemsSource="{Binding ConfigNodes}"
  41. VirtualizingPanel.IsVirtualizing="True"
  42. VirtualizingPanel.VirtualizationMode="Recycling">
  43. <!-- Height should add for VirtualizingPanel, otherwise the App will be slow -->
  44. <TreeView.ItemContainerStyle>
  45. <Style BasedOn="{StaticResource ResourceKey={x:Type TreeViewItem}}" TargetType="{x:Type TreeViewItem}">
  46. <Setter Property="IsExpanded" Value="{Binding IsExpanded}"/>
  47. </Style>
  48. </TreeView.ItemContainerStyle>
  49. <i:Interaction.Triggers>
  50. <i:EventTrigger EventName="SelectedItemChanged">
  51. <i:InvokeCommandAction Command="{Binding TreeViewSelectedItemChangedCmd}" CommandParameter="{Binding Path=SelectedItem, ElementName=PART_TREE}"/>
  52. </i:EventTrigger>
  53. </i:Interaction.Triggers>
  54. </TreeView>
  55. <Grid Grid.Column="1">
  56. <Grid.RowDefinitions>
  57. <RowDefinition Height="45"/>
  58. <RowDefinition/>
  59. </Grid.RowDefinitions>
  60. <Border>
  61. <Grid>
  62. <Grid.ColumnDefinitions>
  63. <ColumnDefinition/>
  64. <ColumnDefinition/>
  65. <ColumnDefinition/>
  66. </Grid.ColumnDefinitions>
  67. <StackPanel Margin="3,0,0,0" Orientation="Horizontal">
  68. <Button
  69. Width="150"
  70. Height="40"
  71. Content="Show All Item"
  72. FontFamily="Arial"
  73. FontSize="16"
  74. Foreground="{DynamicResource FG_Black}"
  75. Visibility="{Binding IsShowAll, UpdateSourceTrigger=PropertyChanged, Converter={StaticResource Bool2CollapsedReverseConverter}}">
  76. <i:Interaction.Triggers>
  77. <i:EventTrigger EventName="Click">
  78. <cal:ActionMessage MethodName="IsShowAllItemClick">
  79. <cal:Parameter Value="true"/>
  80. </cal:ActionMessage>
  81. </i:EventTrigger>
  82. </i:Interaction.Triggers>
  83. </Button>
  84. <Button
  85. Width="auto"
  86. Height="40"
  87. Content="Only the display is different"
  88. FontFamily="Arial"
  89. FontSize="16"
  90. Foreground="{DynamicResource FG_Black}"
  91. Visibility="{Binding IsShowAll, UpdateSourceTrigger=PropertyChanged, Converter={StaticResource bool2VisibilityConverter}}">
  92. <i:Interaction.Triggers>
  93. <i:EventTrigger EventName="Click">
  94. <cal:ActionMessage MethodName="IsShowAllItemClick">
  95. <cal:Parameter Value="false"/>
  96. </cal:ActionMessage>
  97. </i:EventTrigger>
  98. </i:Interaction.Triggers>
  99. </Button>
  100. </StackPanel>
  101. <StackPanel Grid.Column="1" Orientation="Horizontal">
  102. <Border
  103. Grid.Column="1"
  104. Margin="18,0,0,0"
  105. Padding="5,1,0,1"
  106. Background="{DynamicResource Table_BG_Title}"
  107. BorderBrush="{DynamicResource Table_BD}"
  108. BorderThickness="1,1,1,1">
  109. <TextBlock
  110. VerticalAlignment="Center"
  111. FontSize="13"
  112. Foreground="{DynamicResource FG_Black}"
  113. Text="Time:"
  114. TextWrapping="Wrap"/>
  115. </Border>
  116. <Border
  117. Grid.Column="2"
  118. Margin="0,0,4,0"
  119. Padding="5,1"
  120. Background="{DynamicResource Table_BG_Content}"
  121. BorderBrush="{DynamicResource Table_BD}"
  122. BorderThickness="0,1,1,1">
  123. <TextBlock
  124. HorizontalAlignment="Left"
  125. VerticalAlignment="Center"
  126. FontSize="13"
  127. Foreground="{DynamicResource FG_Black}"
  128. Text="{Binding SelectItemNames[1]}"
  129. TextWrapping="Wrap"
  130. ToolTip="{Binding SelectItemNames[1]}"/>
  131. </Border>
  132. </StackPanel>
  133. <StackPanel Grid.Column="2" Orientation="Horizontal">
  134. <Border
  135. Grid.Column="1"
  136. Margin="18,0,0,0"
  137. Padding="5,1,0,1"
  138. Background="{DynamicResource Table_BG_Title}"
  139. BorderBrush="{DynamicResource Table_BD}"
  140. BorderThickness="1,1,1,1">
  141. <TextBlock
  142. VerticalAlignment="Center"
  143. FontSize="13"
  144. Foreground="{DynamicResource FG_Black}"
  145. Text="Time:"
  146. TextWrapping="Wrap"/>
  147. </Border>
  148. <Border
  149. Grid.Column="2"
  150. Margin="0,0,4,0"
  151. Padding="5,1"
  152. Background="{DynamicResource Table_BG_Content}"
  153. BorderBrush="{DynamicResource Table_BD}"
  154. BorderThickness="0,1,1,1">
  155. <TextBlock
  156. HorizontalAlignment="Left"
  157. VerticalAlignment="Center"
  158. FontSize="13"
  159. Foreground="{DynamicResource FG_Black}"
  160. Text="{Binding SelectItemNames[0]}"
  161. TextWrapping="Wrap"
  162. ToolTip="{Binding SelectItemNames[0]}"/>
  163. </Border>
  164. </StackPanel>
  165. </Grid>
  166. </Border>
  167. <DataGrid
  168. Name="dataGrid"
  169. Grid.Row="1"
  170. Height="600"
  171. Margin="3,0,25,0"
  172. AutoGenerateColumns="False"
  173. CanUserAddRows="False"
  174. CanUserReorderColumns="False"
  175. CanUserSortColumns="False"
  176. FontSize="19"
  177. IsReadOnly="True"
  178. ItemsSource="{Binding HistoryTableDatas, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
  179. ScrollViewer.CanContentScroll="True"
  180. ScrollViewer.HorizontalScrollBarVisibility="Auto"
  181. ScrollViewer.VerticalScrollBarVisibility="Auto"
  182. SelectionMode="Single"
  183. SelectionUnit="FullRow"
  184. VirtualizingStackPanel.ScrollUnit="Pixel"
  185. Visibility="{Binding GridHistoryVisibility}">
  186. <DataGrid.Columns>
  187. <DataGridTemplateColumn Width="390" IsReadOnly="True">
  188. <DataGridTemplateColumn.Header>
  189. <TextBlock
  190. HorizontalAlignment="Center"
  191. FontWeight="Bold"
  192. Text="Item Name"/>
  193. </DataGridTemplateColumn.Header>
  194. <DataGridTemplateColumn.CellTemplate>
  195. <DataTemplate>
  196. <Label
  197. Height="45"
  198. HorizontalAlignment="Left"
  199. VerticalAlignment="Top">
  200. <TextBlock
  201. Margin="5,0,5,0"
  202. VerticalAlignment="Center"
  203. Text="{Binding Name}"
  204. TextWrapping="Wrap"/>
  205. </Label>
  206. </DataTemplate>
  207. </DataGridTemplateColumn.CellTemplate>
  208. </DataGridTemplateColumn>
  209. <DataGridTemplateColumn Width="240" IsReadOnly="True">
  210. <DataGridTemplateColumn.Header>
  211. <TextBlock
  212. HorizontalAlignment="Center"
  213. FontWeight="Bold"
  214. Text="Item Value"/>
  215. </DataGridTemplateColumn.Header>
  216. <DataGridTemplateColumn.CellTemplate>
  217. <DataTemplate>
  218. <Label
  219. Width="auto"
  220. Height="45"
  221. VerticalContentAlignment="Center"
  222. Content="{Binding ValueStr}"/>
  223. </DataTemplate>
  224. </DataGridTemplateColumn.CellTemplate>
  225. </DataGridTemplateColumn>
  226. <DataGridTemplateColumn Width="240" IsReadOnly="True">
  227. <DataGridTemplateColumn.Header>
  228. <TextBlock
  229. HorizontalAlignment="Center"
  230. FontWeight="Bold"
  231. Text="Item Value"/>
  232. </DataGridTemplateColumn.Header>
  233. <DataGridTemplateColumn.CellTemplate>
  234. <DataTemplate>
  235. <Label
  236. Width="auto"
  237. Height="45"
  238. VerticalContentAlignment="Center"
  239. Content="{Binding CompareValueStr}"/>
  240. </DataTemplate>
  241. </DataGridTemplateColumn.CellTemplate>
  242. </DataGridTemplateColumn>
  243. </DataGrid.Columns>
  244. <DataGrid.RowStyle>
  245. <Style TargetType="DataGridRow">
  246. <Style.Triggers>
  247. <DataTrigger Binding="{Binding IsDifference}" Value="true">
  248. <Setter Property="Background" Value="Yellow"/>
  249. </DataTrigger>
  250. <DataTrigger Binding="{Binding IsHidden}" Value="True">
  251. <Setter Property="Visibility" Value="Collapsed"/>
  252. </DataTrigger>
  253. </Style.Triggers>
  254. </Style>
  255. </DataGrid.RowStyle>
  256. </DataGrid>
  257. </Grid>
  258. <usercontrols:BusyIndicator
  259. Grid.RowSpan="2"
  260. Grid.ColumnSpan="2"
  261. Width="Auto"
  262. Height="Auto"
  263. Padding="20,10"
  264. HorizontalAlignment="Center"
  265. VerticalAlignment="Center"
  266. HorizontalContentAlignment="Center"
  267. VerticalContentAlignment="Center"
  268. Panel.ZIndex="13"
  269. Background="{StaticResource Tab_BG}"
  270. BorderBrush="Gray"
  271. BorderThickness="3"
  272. Message="{Binding BusyIndicatorContent}"
  273. Visibility="{Binding BusyIndicatorVisibility, UpdateSourceTrigger=PropertyChanged, Converter={StaticResource bool2VisibilityConverter}}"/>
  274. </Grid>
  275. </UserControl>