ProcessHistoryView.xaml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. <UserControl x:Class="Venus_MainPages.Views.ProcessHistoryView"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:prism="http://prismlibrary.com/"
  7. xmlns:local="clr-namespace:Venus_MainPages.Views"
  8. xmlns:wfi ="clr-namespace:System.Windows.Forms.Integration;assembly=WindowsFormsIntegration"
  9. xmlns:forms ="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
  10. prism:ViewModelLocator.AutoWireViewModel="True"
  11. xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
  12. xmlns:ctrls="clr-namespace:Venus_Themes.UserControls;assembly=Venus_Themes"
  13. mc:Ignorable="d"
  14. d:DesignHeight="450" d:DesignWidth="1800"
  15. x:Name="processHistoryView">
  16. <i:Interaction.Triggers>
  17. <i:EventTrigger EventName="Loaded">
  18. <i:InvokeCommandAction Command="{Binding LoadCommandPD}" CommandParameter="{Binding ElementName=processHistoryView}"/>
  19. </i:EventTrigger>
  20. </i:Interaction.Triggers>
  21. <UserControl.Resources>
  22. <Style TargetType="{x:Type DataGridColumnHeader}">
  23. <Setter Property="SnapsToDevicePixels" Value="True"/>
  24. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  25. <Setter Property="BorderBrush" Value="{DynamicResource DataGrid_Header_BD}"/>
  26. <Setter Property="BorderThickness" Value="0,0,1,0"/>
  27. <Setter Property="Padding" Value="5,1"/>
  28. <Setter Property="Background" Value="{DynamicResource Table_BG_Title}"/>
  29. <Setter Property="Foreground" Value="{DynamicResource FG_Black}"/>
  30. <Setter Property="FontFamily" Value="Arial"/>
  31. <Setter Property="MinHeight" Value="24"/>
  32. <Setter Property="Template">
  33. <Setter.Value>
  34. <ControlTemplate TargetType="{x:Type DataGridColumnHeader}">
  35. <Border BorderThickness="{TemplateBinding BorderThickness}" BorderBrush="{TemplateBinding BorderBrush}" Background="{TemplateBinding Background}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" Cursor="Hand">
  36. <Grid>
  37. <Path x:Name="Arrow" Visibility="Collapsed" Data="M0,0 L1,0 0.5,1 z" Stretch="Fill" Width="8" Height="4" Fill="{DynamicResource DataGrid_ArrowBG}" Margin="0,2,0,0" HorizontalAlignment="Center" VerticalAlignment="Top" RenderTransformOrigin="0.5,0.4" />
  38. <ContentPresenter Margin="{TemplateBinding Padding}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}">
  39. <ContentPresenter.Effect>
  40. <DropShadowEffect BlurRadius="0" ShadowDepth="1" Direction="315"/>
  41. </ContentPresenter.Effect>
  42. </ContentPresenter>
  43. <Thumb x:Name="PART_RightHeaderGripper" Style="{StaticResource ColumnHeaderGripperStyle}" HorizontalAlignment="Right"/>
  44. </Grid>
  45. </Border>
  46. <ControlTemplate.Triggers>
  47. <Trigger Property="SortDirection" Value="Ascending">
  48. <Setter TargetName="Arrow" Property="Visibility" Value="Visible" />
  49. <Setter TargetName="Arrow" Property="RenderTransform">
  50. <Setter.Value>
  51. <RotateTransform Angle="180" />
  52. </Setter.Value>
  53. </Setter>
  54. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  55. </Trigger>
  56. <Trigger Property="SortDirection" Value="Descending">
  57. <Setter TargetName="Arrow" Property="Visibility" Value="Visible" />
  58. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  59. </Trigger>
  60. <MultiTrigger>
  61. <MultiTrigger.Conditions>
  62. <Condition Property="IsMouseOver" Value="True" />
  63. <Condition Property="SortDirection" Value="{x:Null}" />
  64. </MultiTrigger.Conditions>
  65. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  66. </MultiTrigger>
  67. </ControlTemplate.Triggers>
  68. </ControlTemplate>
  69. </Setter.Value>
  70. </Setter>
  71. </Style>
  72. </UserControl.Resources>
  73. <Grid>
  74. <Grid.RowDefinitions>
  75. <RowDefinition Height="Auto"></RowDefinition>
  76. <RowDefinition Height="2*" ></RowDefinition>
  77. <RowDefinition Height="5" ></RowDefinition>
  78. <RowDefinition Height="4*" ></RowDefinition>
  79. </Grid.RowDefinitions>
  80. <Grid Grid.Row="0" Grid.Column="0">
  81. <Grid.RowDefinitions>
  82. <RowDefinition Height="40"/>
  83. </Grid.RowDefinitions>
  84. <Grid.ColumnDefinitions>
  85. <ColumnDefinition Width="100"/>
  86. <ColumnDefinition Width="*"/>
  87. <ColumnDefinition Width="100"/>
  88. <ColumnDefinition Width="*"/>
  89. <ColumnDefinition Width="100"/>
  90. <ColumnDefinition Width="*"/>
  91. <ColumnDefinition Width="100"/>
  92. </Grid.ColumnDefinitions>
  93. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1" Height="40">
  94. <TextBlock Text="Start" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center"></TextBlock>
  95. </Border>
  96. <Border Grid.Column="1" Background="#FFDAE5F1" BorderThickness="1" Padding="5,1">
  97. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="30" VerticalAlignment="Center">
  98. <forms:DateTimePicker x:Name="wfTimeFrom" Value="2023-5-3" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></forms:DateTimePicker>
  99. </wfi:WindowsFormsHost>
  100. </Border>
  101. <Border Grid.Column="2" BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  102. <TextBlock Text="End" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center"></TextBlock>
  103. </Border>
  104. <Border Grid.Column="3" BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Content}" Padding="5,1">
  105. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="30" VerticalAlignment="Center">
  106. <forms:DateTimePicker x:Name="wfTimeTo" Value="2023-5-30" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></forms:DateTimePicker>
  107. </wfi:WindowsFormsHost>
  108. </Border>
  109. <Border Grid.Row="0" Grid.Column="4" BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  110. <TextBlock Text="Recipe" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center"></TextBlock>
  111. </Border>
  112. <Border Grid.Row="0" Grid.Column="5" BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Content}" Padding="5,1">
  113. <Grid HorizontalAlignment="Center">
  114. <!--<ComboBox Width="400" ItemsSource="{Binding CheboxRecipes, Mode=TwoWay}" SelectedValue="{Binding RecipeName ,Mode=TwoWay}" DisplayMemberPath="BoxName" SelectedValuePath="BoxName">
  115. </ComboBox>-->
  116. <TextBox Text="{Binding RecipeName,UpdateSourceTrigger=PropertyChanged}" Width="400" VerticalContentAlignment="Center" FontSize="15"/>
  117. </Grid>
  118. </Border>
  119. <Button Margin="5,0,0,0" Grid.Column="6" Content="Search" Width="80" Height="30" Command="{Binding SearchRecipeCommand}">
  120. </Button>
  121. </Grid>
  122. <Grid Grid.Row="1">
  123. <Grid.ColumnDefinitions>
  124. <ColumnDefinition Width="543*"/>
  125. <ColumnDefinition Width="Auto"/>
  126. <ColumnDefinition Width="10*"/>
  127. <ColumnDefinition Width="26*"/>
  128. <ColumnDefinition Width="358*"/>
  129. <ColumnDefinition Width="423*"/>
  130. <ColumnDefinition Width="143*"/>
  131. <ColumnDefinition Width="240*"/>
  132. <ColumnDefinition Width="19*"/>
  133. <ColumnDefinition Width="37*"/>
  134. </Grid.ColumnDefinitions>
  135. <Grid.RowDefinitions>
  136. <RowDefinition Height="25"/>
  137. <RowDefinition/>
  138. </Grid.RowDefinitions>
  139. <Button Grid.Row="0" Content="导出列表" FontSize="10" Height="18" Margin="0,5,12,0" x:Name="ButtonExportList" VerticalAlignment="Top" IsEnabled="False" HorizontalAlignment="Right" Width="106" Grid.ColumnSpan="3" Grid.Column="7" Click="buttonLotListExport_Click"/>
  140. <DataGrid Grid.Row="1" ItemsSource="{Binding Recipes}" AutoGenerateColumns="False" CanUserAddRows="False" Name="dataGrid_RecipeList"
  141. CanUserResizeRows="False" CanUserResizeColumns="True" FontFamily="Arial" Margin="0,5,0,0" Grid.ColumnSpan="10" >
  142. <i:Interaction.Triggers>
  143. <i:EventTrigger EventName="SelectionChanged">
  144. <i:InvokeCommandAction Command="{Binding DataGridSelectionChangedCommand}" CommandParameter="{Binding ElementName=dataGrid_RecipeList,Path=SelectedValue}"/>
  145. </i:EventTrigger>
  146. </i:Interaction.Triggers>
  147. <DataGrid.Columns>
  148. <DataGridTemplateColumn Header="checked" Width="100">
  149. <DataGridTemplateColumn.CellTemplate>
  150. <DataTemplate>
  151. <CheckBox IsChecked="{Binding Selected,Mode=TwoWay}" VerticalAlignment="Center" HorizontalAlignment="Center" />
  152. </DataTemplate>
  153. </DataGridTemplateColumn.CellTemplate>
  154. </DataGridTemplateColumn>
  155. <DataGridTemplateColumn Header="Lot ID" Width="320">
  156. <DataGridTemplateColumn.CellTemplate>
  157. <DataTemplate>
  158. <TextBlock Text="{Binding LotID}" Margin="5,0" FontFamily="Arial" FontSize="14" Background="White" Foreground="White" HorizontalAlignment="Left" VerticalAlignment="Center" />
  159. </DataTemplate>
  160. </DataGridTemplateColumn.CellTemplate>
  161. </DataGridTemplateColumn>
  162. <DataGridTemplateColumn Header="Slot ID" Width="320">
  163. <DataGridTemplateColumn.CellTemplate>
  164. <DataTemplate>
  165. <TextBlock Text="{Binding SlotID}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  166. </DataTemplate>
  167. </DataGridTemplateColumn.CellTemplate>
  168. </DataGridTemplateColumn>
  169. <DataGridTemplateColumn Header="Start" Width="200">
  170. <DataGridTemplateColumn.CellTemplate>
  171. <DataTemplate>
  172. <TextBlock Text="{Binding StartTime}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  173. </DataTemplate>
  174. </DataGridTemplateColumn.CellTemplate>
  175. </DataGridTemplateColumn>
  176. <DataGridTemplateColumn Header="End" Width="200">
  177. <DataGridTemplateColumn.CellTemplate>
  178. <DataTemplate>
  179. <TextBlock Text="{Binding EndTime}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  180. </DataTemplate>
  181. </DataGridTemplateColumn.CellTemplate>
  182. </DataGridTemplateColumn>
  183. <DataGridTemplateColumn Header="Chamber" Width="80">
  184. <DataGridTemplateColumn.CellTemplate>
  185. <DataTemplate>
  186. <TextBlock Text="{Binding Chamber}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  187. </DataTemplate>
  188. </DataGridTemplateColumn.CellTemplate>
  189. </DataGridTemplateColumn>
  190. <!--<DataGridTemplateColumn Header="Wafer ID" Width="320">
  191. <DataGridTemplateColumn.CellTemplate>
  192. <DataTemplate>
  193. <TextBlock Text="{Binding RecipeRunGuid}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  194. </DataTemplate>
  195. </DataGridTemplateColumn.CellTemplate>
  196. </DataGridTemplateColumn>-->
  197. <DataGridTemplateColumn Header="Recipe" Width="300">
  198. <DataGridTemplateColumn.CellTemplate>
  199. <DataTemplate>
  200. <TextBlock Text="{Binding Recipe}" Margin="5,0" FontFamily="Arial" FontSize="20" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  201. </DataTemplate>
  202. </DataGridTemplateColumn.CellTemplate>
  203. </DataGridTemplateColumn>
  204. <DataGridTemplateColumn Header="Status" Width="*">
  205. <DataGridTemplateColumn.CellTemplate>
  206. <DataTemplate>
  207. <TextBlock Text="{Binding Status}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  208. </DataTemplate>
  209. </DataGridTemplateColumn.CellTemplate>
  210. </DataGridTemplateColumn>
  211. </DataGrid.Columns>
  212. </DataGrid>
  213. </Grid>
  214. <GridSplitter Grid.Row="2" Background="LightBlue" HorizontalAlignment="Stretch" VerticalAlignment="Center" Height="5" Margin="0">
  215. </GridSplitter>
  216. <Grid Grid.Row="2" Margin="0,0,0,5" Grid.RowSpan="2" >
  217. <Grid.RowDefinitions>
  218. <RowDefinition Height="25"></RowDefinition>
  219. <RowDefinition Height="*"></RowDefinition>
  220. </Grid.RowDefinitions>
  221. <Button Grid.Row="0" Content="导出数据" FontSize="10" Height="18" Margin="0,5,12,0" x:Name="ButtonExportData" IsEnabled="False" VerticalAlignment="Top" HorizontalAlignment="Right" Width="106" Click="buttonLotDetailsExport_Click" />
  222. <Grid Grid.Row="1" Margin="10,5,10,5">
  223. <Grid.ColumnDefinitions>
  224. <ColumnDefinition Width="20*"/>
  225. <ColumnDefinition Width="256*"/>
  226. <ColumnDefinition Width="20*"/>
  227. <ColumnDefinition Width="12*"/>
  228. <ColumnDefinition Width="1454*"/>
  229. <ColumnDefinition Width="19*"/>
  230. </Grid.ColumnDefinitions>
  231. <Grid Grid.Column="1" Grid.ColumnSpan="2" Margin="0,0,19,0">
  232. <StackPanel>
  233. <TreeView x:Name="ParameterTreeView" ItemsSource="{Binding ParameterNodes}" Canvas.Top="100" Height="300">
  234. <TreeView.ItemTemplate>
  235. <HierarchicalDataTemplate ItemsSource="{Binding ChildNodes}">
  236. <StackPanel Orientation="Horizontal">
  237. <CheckBox IsChecked="{Binding Selected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" >
  238. <i:Interaction.Triggers>
  239. <i:EventTrigger EventName="Click">
  240. <i:InvokeCommandAction Command="{Binding DataContext.PdParameterCheckCommand, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=TreeView}}" CommandParameter="{Binding }"/>
  241. </i:EventTrigger>
  242. </i:Interaction.Triggers>
  243. </CheckBox>
  244. <TextBlock Text="{Binding Name}" />
  245. </StackPanel>
  246. </HierarchicalDataTemplate>
  247. </TreeView.ItemTemplate>
  248. </TreeView>
  249. <StackPanel Orientation="Horizontal" HorizontalAlignment="Center">
  250. <Button Width="100" Content="Search" Command="{Binding SearchDataCommand}"/>
  251. <Button Width="100" Content="Clear" Margin="10,0,0,0" Command="{Binding ClearDataCommand}"/>
  252. </StackPanel>
  253. <ListBox ItemsSource="{Binding PdKeyDataCollection}" Margin="20,0,0,0" FontSize="14" Height="auto" VerticalAlignment="Bottom">
  254. <ListBox.ItemTemplate>
  255. <DataTemplate>
  256. <StackPanel Orientation="Horizontal">
  257. <TextBlock Text="{Binding Key}" Width="223"/>
  258. <Ellipse Fill="{Binding Color}" Width="15" Height="15" Margin="10,0,0,0"/>
  259. </StackPanel>
  260. </DataTemplate>
  261. </ListBox.ItemTemplate>
  262. </ListBox>
  263. </StackPanel>
  264. </Grid>
  265. <ctrls:DrawGraphicsControl Grid.Column="3" x:Name="MyDrawGraphicsControl" IsHorizontalNavigationEnabled="{Binding ElementName=AutoXCheckBox,Path=IsChecked}" IsVerticalNavigationEnabled="{Binding ElementName=AutoYCheckBox,Path=IsChecked}" WavePlotOriginX="{Binding ElementName=MinXTextBox,Path=Text}" WavePlotOriginWidth="{Binding ElementName=MaxXTextBox,Path=Text}" WavePlotOriginY="{Binding ElementName=MinYTextBox,Path=Text}" WavePlotOriginHeight="{Binding ElementName=MaxYTextBox,Path=Text,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" IsHorizontalDateTimeAxis="True" HorizontalAlignment="Left" Width="1477" Margin="11,10,0,5" Grid.ColumnSpan="3"/>
  266. </Grid>
  267. </Grid>
  268. </Grid>
  269. </UserControl>