FolderQuestionedManagement.xaml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <UserControl x:Class="aipdev.FolderQuestionedManagement"
  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:local="clr-namespace:aipdev"
  7. xmlns:extensions="clr-namespace:aipdev.Extensions"
  8. mc:Ignorable="d"
  9. d:DesignHeight="450" d:DesignWidth="800">
  10. <Grid>
  11. <Grid.RowDefinitions>
  12. <RowDefinition Height="50"/>
  13. <RowDefinition Height="*"/>
  14. </Grid.RowDefinitions>
  15. <Button Grid.Row="0" HorizontalAlignment="Left" Margin="2" VerticalAlignment="Center" Content="刷新" Click="OnRefreshServerFoldersClick"/>
  16. <TreeView x:Name="ServerFolders" Grid.Row="1" Grid.Column="0">
  17. <TreeView.Resources>
  18. <Style x:Key="ExpandCollapseToggleStyle" TargetType="ToggleButton">
  19. <Setter Property="Focusable" Value="False"/>
  20. <Setter Property="Background" Value="Transparent"/>
  21. <Setter Property="BorderBrush" Value="#FF565656"/>
  22. <Setter Property="Template">
  23. <Setter.Value>
  24. <ControlTemplate TargetType="ToggleButton">
  25. <Grid>
  26. <!-- 画折叠样式 -->
  27. <Border x:Name="CollapsePath" Height="14" Width="10" SnapsToDevicePixels="True" Background="{TemplateBinding Background}">
  28. <!--<Rectangle x:Name="CollapsePath" Width="1" Height="5" Stroke="{TemplateBinding Background}" SnapsToDevicePixels="true"/>-->
  29. <Path Data="M 0,0 8,7 0,14" Stretch="Fill"
  30. Stroke="{TemplateBinding BorderBrush}" StrokeThickness="1.5"
  31. Height="14" Width="8"
  32. VerticalAlignment="Center"
  33. HorizontalAlignment="Center"
  34. Margin="0,0,0,0">
  35. <Path.LayoutTransform>
  36. <TransformGroup>
  37. <ScaleTransform/>
  38. <SkewTransform/>
  39. <RotateTransform Angle="0"/>
  40. <TranslateTransform/>
  41. </TransformGroup>
  42. </Path.LayoutTransform>
  43. </Path>
  44. </Border>
  45. <!-- 画展开折叠样式 -->
  46. <Border x:Name="ExpandPath" Height="10" Width="14" SnapsToDevicePixels="True" Background="{TemplateBinding Background}" Visibility="Collapsed">
  47. <!--<Rectangle x:Name="ExpandPath" Width="1" Height="5" Stroke="{TemplateBinding Background}" SnapsToDevicePixels="true"/>-->
  48. <Path Data="M 0,0 8,7 0,14" Stretch="Fill"
  49. Stroke="{TemplateBinding BorderBrush}" StrokeThickness="1.5"
  50. Height="14" Width="8"
  51. VerticalAlignment="Center"
  52. HorizontalAlignment="Center"
  53. Margin="0,0,0,0">
  54. <Path.LayoutTransform>
  55. <TransformGroup>
  56. <ScaleTransform/>
  57. <SkewTransform/>
  58. <RotateTransform Angle="90"/>
  59. <TranslateTransform/>
  60. </TransformGroup>
  61. </Path.LayoutTransform>
  62. </Path>
  63. </Border>
  64. </Grid>
  65. <ControlTemplate.Triggers>
  66. <!-- 通过IsChecked判断折叠还是展开 -->
  67. <Trigger Property="IsChecked" Value="True">
  68. <Setter Property="Visibility" TargetName="CollapsePath" Value="Collapsed"/>
  69. <Setter Property="Visibility" TargetName="ExpandPath" Value="Visible"/>
  70. </Trigger>
  71. </ControlTemplate.Triggers>
  72. </ControlTemplate>
  73. </Setter.Value>
  74. </Setter>
  75. </Style>
  76. <HierarchicalDataTemplate DataType= "{x:Type local:ImageFolderExtend}" ItemsSource = "{Binding Path=Children}">
  77. <Grid>
  78. <Grid.ColumnDefinitions>
  79. <ColumnDefinition Width="24"/>
  80. <ColumnDefinition Width="*"/>
  81. </Grid.ColumnDefinitions>
  82. <Image Grid.Column="0" VerticalAlignment="Center" HorizontalAlignment="Center"
  83. Source="{Binding Path=DataContext,RelativeSource={RelativeSource Mode=Self}, Converter={extensions:FolderLevelToImageConverter}}" Width="20" Height="20"/>
  84. <TextBlock Grid.Column="1" VerticalAlignment="Center" Text="{Binding Description}" Foreground="Black" Margin="2,0,0,0" FontSize="14px"/>
  85. <Grid.ContextMenu>
  86. <ContextMenu Visibility="{Binding HasMenu, Converter={extensions:BoolToVisibilityConverter}}">
  87. <MenuItem Header="查看..." IsEnabled="{Binding IsEnabled}" Click="OnOpenFolderClick"/>
  88. </ContextMenu>
  89. </Grid.ContextMenu>
  90. </Grid>
  91. </HierarchicalDataTemplate>
  92. </TreeView.Resources>
  93. <TreeView.ItemContainerStyle>
  94. <Style TargetType="{x:Type TreeViewItem}">
  95. <Setter Property="IsExpanded" Value="True" />
  96. <Setter Property="Background" Value="Transparent"/>
  97. <Setter Property="Padding" Value="1,0,0,0"/>
  98. <Setter Property="Template">
  99. <Setter.Value>
  100. <ControlTemplate TargetType="{x:Type TreeViewItem}">
  101. <Grid>
  102. <Grid.ColumnDefinitions>
  103. <ColumnDefinition MinWidth="20" Width="Auto"/>
  104. <ColumnDefinition Width="Auto"/>
  105. <ColumnDefinition Width="*"/>
  106. </Grid.ColumnDefinitions>
  107. <Grid.RowDefinitions>
  108. <RowDefinition Height="Auto"/>
  109. <RowDefinition/>
  110. </Grid.RowDefinitions>
  111. <Border Name="FocusBd" Margin="-100,0,0,0" Grid.Row="0" Grid.Column="0" Grid.ColumnSpan="3" Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Padding="{TemplateBinding Padding}" SnapsToDevicePixels="True"></Border>
  112. <Border Name="Bd" Grid.Row="0" Grid.Column="0" Grid.ColumnSpan="3" Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Padding="{TemplateBinding Padding}" SnapsToDevicePixels="True">
  113. <Grid Margin="2">
  114. <Grid.ColumnDefinitions>
  115. <ColumnDefinition Width="Auto"/>
  116. <ColumnDefinition Width="Auto"/>
  117. <ColumnDefinition Width="*"/>
  118. </Grid.ColumnDefinitions>
  119. <ToggleButton Width="18" Grid.Column="0" Margin="-1,0,0,0" x:Name="Expander" Style="{StaticResource ExpandCollapseToggleStyle}" IsChecked="{Binding Path=IsExpanded, RelativeSource={RelativeSource TemplatedParent}}" ClickMode="Press"/>
  120. <ContentPresenter Grid.Column="2" x:Name="PART_Header" ContentSource="Header" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" MinWidth="20"/>
  121. </Grid>
  122. </Border>
  123. <ItemsPresenter x:Name="ItemsHost" Grid.Row="1" Grid.Column="1" Grid.ColumnSpan="2"/>
  124. </Grid>
  125. <ControlTemplate.Triggers>
  126. <Trigger Property="IsExpanded" Value="False">
  127. <Setter TargetName="ItemsHost" Property="Visibility" Value="Collapsed"/>
  128. </Trigger>
  129. <Trigger Property="HasItems" Value="False">
  130. <Setter TargetName="Expander" Property="Visibility" Value="Collapsed"/>
  131. </Trigger>
  132. <MultiTrigger>
  133. <MultiTrigger.Conditions>
  134. <Condition Property="HasHeader" Value="False"/>
  135. <Condition Property="Width" Value="Auto"/>
  136. </MultiTrigger.Conditions>
  137. <Setter TargetName="PART_Header" Property="MinWidth" Value="75"/>
  138. </MultiTrigger>
  139. <MultiTrigger>
  140. <MultiTrigger.Conditions>
  141. <Condition Property="HasHeader" Value="False"/>
  142. <Condition Property="Height" Value="Auto"/>
  143. </MultiTrigger.Conditions>
  144. <Setter TargetName="PART_Header" Property="MinHeight" Value="19"/>
  145. </MultiTrigger>
  146. <Trigger Property="IsSelected" Value="True">
  147. <Setter TargetName="FocusBd" Property="Background" Value="#C4D5FF"/>
  148. <Setter TargetName="Bd" Property="Background" Value="#C4D5FF"/>
  149. </Trigger>
  150. <Trigger Property="IsEnabled" Value="False">
  151. <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.GrayTextBrushKey}}"/>
  152. </Trigger>
  153. </ControlTemplate.Triggers>
  154. </ControlTemplate>
  155. </Setter.Value>
  156. </Setter>
  157. <EventSetter Event="MouseDoubleClick" Handler="OnNodeDoubleClickHandler"></EventSetter>
  158. <EventSetter Event="MouseDown" Handler="OnNodeMouseDown"></EventSetter>
  159. </Style>
  160. </TreeView.ItemContainerStyle>
  161. </TreeView>
  162. </Grid>
  163. </UserControl>