App.xaml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. <Application x:Class="PRSDesktop.App"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:syncfusion="http://schemas.syncfusion.com/wpf"
  5. xmlns:themes="clr-namespace:InABox.WPF.Themes;assembly=InABox.Wpf"
  6. xmlns:fluent="urn:fluent-ribbon"
  7. xmlns:prsDesktop="clr-namespace:PRSDesktop">
  8. <Application.Resources>
  9. <ResourceDictionary>
  10. <themes:ThemeManager x:Key="Theme"/>
  11. <ResourceDictionary.MergedDictionaries>
  12. <ResourceDictionary Source="pack://application:,,,/Fluent;Component/Themes/Generic.xaml" />
  13. <ResourceDictionary>
  14. <Style x:Key="VirtualisedItemsControlStyle" TargetType="ItemsControl">
  15. <Setter Property="VirtualizingPanel.IsVirtualizing" Value="True"/>
  16. <Setter Property="ItemsPanel">
  17. <Setter.Value>
  18. <ItemsPanelTemplate>
  19. <VirtualizingStackPanel/>
  20. </ItemsPanelTemplate>
  21. </Setter.Value>
  22. </Setter>
  23. <Setter Property="Template">
  24. <Setter.Value>
  25. <ControlTemplate TargetType="ItemsControl">
  26. <Border BorderThickness="{TemplateBinding BorderThickness}"
  27. BorderBrush="{TemplateBinding BorderBrush}"
  28. Background="{TemplateBinding Background}"
  29. SnapsToDevicePixels="True">
  30. <ScrollViewer CanContentScroll="True"
  31. Padding="{TemplateBinding Padding}"
  32. Focusable="False"
  33. VerticalScrollBarVisibility="Auto">
  34. <ItemsPresenter/>
  35. </ScrollViewer>
  36. </Border>
  37. </ControlTemplate>
  38. </Setter.Value>
  39. </Setter>
  40. </Style>
  41. <Style x:Key="TemplateHeaderStyle" TargetType="{x:Type syncfusion:GridHeaderCellControl}">
  42. <Setter Property="Background" Value="LightSkyBlue"/>
  43. <Setter Property="Foreground" Value="Black"/>
  44. <Setter Property="BorderBrush" Value="Black"/>
  45. <Setter Property="BorderThickness" Value="0.5,0.5,0.5,0.5"/>
  46. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  47. <Setter Property="VerticalContentAlignment" Value="Center"/>
  48. <Setter Property="Padding" Value="5,3"/>
  49. <Setter Property="FontFamily" Value="Segoe UI"/>
  50. <Setter Property="FontSize" Value="14"/>
  51. <Setter Property="FontWeight" Value="Normal"/>
  52. <Setter Property="IsTabStop" Value="False"/>
  53. </Style>
  54. <Style TargetType="fluent:RibbonTabItem">
  55. <Setter Property="HeaderPadding" Value="20,0,20,0" />
  56. <Setter Property="Margin" Value="0,0,5,0" />
  57. <Setter Property="MinWidth" Value="80"/>
  58. <Setter Property="Height" Value="30" />
  59. </Style>
  60. <Style TargetType="fluent:Button">
  61. <Setter Property="MinWidth" Value="60" />
  62. </Style>
  63. <Style TargetType="fluent:Backstage">
  64. <Setter Property="Height" Value="30" />
  65. <Setter Property="Margin" Value="0,0,5,0" />
  66. <!-- <Setter Property="MinWidth" Value="100"/> -->
  67. <Setter Property="Padding" Value="20,0,20,0" />
  68. </Style>
  69. <ControlTemplate x:Key="VerticalSplitter">
  70. <Grid Background="{TemplateBinding Background}" Width="4">
  71. <Button x:Name="PART_Left" Visibility="Collapsed" />
  72. <Button x:Name="PART_Right" Visibility="Collapsed" />
  73. <StackPanel Margin="0" Orientation="Vertical" VerticalAlignment="Center"
  74. HorizontalAlignment="Center">
  75. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  76. Margin="0,2,0,0" />
  77. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  78. Margin="0,2,0,0" />
  79. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  80. Margin="0,2,0,0" />
  81. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  82. Margin="0,2,0,0" />
  83. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  84. Margin="0,2,0,0" />
  85. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  86. Margin="0,2,0,0" />
  87. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  88. Margin="0,2,0,0" />
  89. </StackPanel>
  90. </Grid>
  91. </ControlTemplate>
  92. <ControlTemplate x:Key="HorizontalSplitter">
  93. <Grid Background="{TemplateBinding Background}" Height="4">
  94. <Grid.ColumnDefinitions>
  95. <ColumnDefinition Width="*" />
  96. <ColumnDefinition Width="Auto" />
  97. <ColumnDefinition Width="*" />
  98. </Grid.ColumnDefinitions>
  99. <Button Grid.Column="0" x:Name="PART_Left" Visibility="Collapsed" />
  100. <StackPanel Grid.Column="1" Margin="0" Orientation="Horizontal"
  101. HorizontalAlignment="Center"
  102. VerticalAlignment="Center">
  103. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  104. Margin="2,0,0,0" />
  105. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  106. Margin="2,0,0,0" />
  107. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  108. Margin="2,0,0,0" />
  109. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  110. Margin="2,0,0,0" />
  111. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  112. Margin="2,0,0,0" />
  113. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  114. Margin="2,0,0,0" />
  115. <Ellipse Fill="Silver" HorizontalAlignment="Center" Height="2" Width="2" Opacity="1"
  116. Margin="2,0,0,0" />
  117. </StackPanel>
  118. <Button Grid.Column="2" x:Name="PART_Right" Visibility="Collapsed" />
  119. </Grid>
  120. </ControlTemplate>
  121. <ControlTemplate x:Key="VerticalColumnHeader"
  122. TargetType="{x:Type syncfusion:GridHeaderCellControl}">
  123. <Grid>
  124. <Grid.LayoutTransform>
  125. <RotateTransform Angle="270" />
  126. </Grid.LayoutTransform>
  127. <VisualStateManager.VisualStateGroups>
  128. <VisualStateGroup x:Name="HiddenColumnsResizingStates">
  129. <VisualState x:Name="PreviousColumnHidden">
  130. <Storyboard>
  131. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  132. Storyboard.TargetProperty="BorderThickness"
  133. Storyboard.TargetName="PART_HeaderCellBorder">
  134. <EasingThicknessKeyFrame KeyTime="0" Value="3,0,1,1" />
  135. </ThicknessAnimationUsingKeyFrames>
  136. </Storyboard>
  137. </VisualState>
  138. <VisualState x:Name="HiddenState">
  139. <Storyboard>
  140. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  141. Storyboard.TargetProperty="BorderThickness"
  142. Storyboard.TargetName="PART_HeaderCellBorder">
  143. <EasingThicknessKeyFrame KeyTime="0" Value="3,0,3,1" />
  144. </ThicknessAnimationUsingKeyFrames>
  145. </Storyboard>
  146. </VisualState>
  147. <VisualState x:Name="NormalState" />
  148. <VisualState x:Name="LastColumnHidden">
  149. <Storyboard>
  150. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  151. Storyboard.TargetProperty="BorderThickness"
  152. Storyboard.TargetName="PART_HeaderCellBorder">
  153. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,3,1" />
  154. </ThicknessAnimationUsingKeyFrames>
  155. </Storyboard>
  156. </VisualState>
  157. </VisualStateGroup>
  158. <VisualStateGroup x:Name="CommonStates">
  159. <VisualState x:Name="MouseOver" />
  160. <VisualState x:Name="Normal" />
  161. </VisualStateGroup>
  162. <VisualStateGroup x:Name="BorderStates">
  163. <VisualState x:Name="NormalCell" />
  164. <VisualState x:Name="FooterColumnCell">
  165. <Storyboard BeginTime="0">
  166. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  167. Storyboard.TargetProperty="BorderThickness"
  168. Storyboard.TargetName="PART_FooterCellBorder">
  169. <EasingThicknessKeyFrame KeyTime="0" Value="1,0,1,1" />
  170. </ThicknessAnimationUsingKeyFrames>
  171. </Storyboard>
  172. </VisualState>
  173. <VisualState x:Name="BeforeFooterColumnCell">
  174. <Storyboard BeginTime="0">
  175. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  176. Storyboard.TargetProperty="BorderThickness"
  177. Storyboard.TargetName="PART_FooterCellBorder">
  178. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,1" />
  179. </ThicknessAnimationUsingKeyFrames>
  180. <ThicknessAnimationUsingKeyFrames BeginTime="0" Duration="1.0:0:0"
  181. Storyboard.TargetProperty="BorderThickness"
  182. Storyboard.TargetName="PART_HeaderCellBorder">
  183. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,1" />
  184. </ThicknessAnimationUsingKeyFrames>
  185. </Storyboard>
  186. </VisualState>
  187. </VisualStateGroup>
  188. </VisualStateManager.VisualStateGroups>
  189. <Border x:Name="PART_FooterCellBorder" BorderBrush="{TemplateBinding BorderBrush}"
  190. Background="{TemplateBinding Background}" />
  191. <Border x:Name="PART_HeaderCellBorder" BorderBrush="{TemplateBinding BorderBrush}"
  192. BorderThickness="{TemplateBinding BorderThickness}"
  193. Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  194. <Grid Margin="{TemplateBinding Padding}" SnapsToDevicePixels="True">
  195. <Grid.ColumnDefinitions>
  196. <ColumnDefinition Width="*" />
  197. <ColumnDefinition Width="Auto" />
  198. <ColumnDefinition Width="Auto" />
  199. </Grid.ColumnDefinitions>
  200. <ContentPresenter
  201. ContentTemplate="{TemplateBinding ContentTemplate}"
  202. ContentStringFormat="{TemplateBinding ContentStringFormat}" Focusable="False"
  203. HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
  204. VerticalAlignment="{TemplateBinding VerticalContentAlignment}">
  205. <ContentPresenter.Content>
  206. <TextBlock Text="{Binding HeaderText}" TextWrapping="Wrap" />
  207. </ContentPresenter.Content>
  208. </ContentPresenter>
  209. <Grid x:Name="PART_SortButtonPresenter" Grid.Column="1" SnapsToDevicePixels="True">
  210. <Grid.ColumnDefinitions>
  211. <ColumnDefinition Width="*">
  212. <ColumnDefinition.MinWidth>
  213. <Binding Mode="OneWay" Path="SortDirection"
  214. RelativeSource="{RelativeSource TemplatedParent}">
  215. <Binding.Converter>
  216. <syncfusion:SortDirectionToWidthConverter />
  217. </Binding.Converter>
  218. </Binding>
  219. </ColumnDefinition.MinWidth>
  220. </ColumnDefinition>
  221. <ColumnDefinition Width="*" />
  222. </Grid.ColumnDefinitions>
  223. <TextBlock Grid.Column="1" Foreground="{TemplateBinding Foreground}"
  224. FontSize="10" Margin="0,-4,0,0" SnapsToDevicePixels="True"
  225. Text="{TemplateBinding SortNumber}"
  226. Visibility="{TemplateBinding SortNumberVisibility}"
  227. VerticalAlignment="Bottom" />
  228. </Grid>
  229. <syncfusion:FilterToggleButton x:Name="PART_FilterToggleButton" Grid.Column="2"
  230. HorizontalAlignment="Stretch"
  231. SnapsToDevicePixels="True"
  232. Visibility="{TemplateBinding FilterIconVisiblity}"
  233. VerticalAlignment="Stretch">
  234. <syncfusion:FilterToggleButton.LayoutTransform>
  235. <RotateTransform Angle="90" />
  236. </syncfusion:FilterToggleButton.LayoutTransform>
  237. </syncfusion:FilterToggleButton>
  238. <Border x:Name="PART_FilterPopUpPresenter">
  239. <Border.LayoutTransform>
  240. <RotateTransform Angle="90" />
  241. </Border.LayoutTransform>
  242. </Border>
  243. </Grid>
  244. </Border>
  245. </Grid>
  246. </ControlTemplate>
  247. <Style x:Key="HorizontalSplitterPreview" TargetType="Control">
  248. <Setter Property="Background" Value="Gray" />
  249. <Setter Property="Template">
  250. <Setter.Value>
  251. <ControlTemplate TargetType="Control">
  252. <Grid x:Name="Root" Opacity="0.5">
  253. <Rectangle Fill="{TemplateBinding Background}" />
  254. </Grid>
  255. </ControlTemplate>
  256. </Setter.Value>
  257. </Setter>
  258. </Style>
  259. </ResourceDictionary>
  260. </ResourceDictionary.MergedDictionaries>
  261. </ResourceDictionary>
  262. </Application.Resources>
  263. </Application>