TodoControl.xaml 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. <UserControl x:Class="GeekDesk.Control.UserControls.Backlog.TodoControl"
  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:GeekDesk.Control.UserControls.PannelCard"
  7. xmlns:hc="https://handyorg.github.io/handycontrol" xmlns:viewmodel="clr-namespace:GeekDesk.ViewModel" d:DataContext="{d:DesignInstance Type=viewmodel:ToDoInfo}"
  8. mc:Ignorable="d"
  9. xmlns:cst="clr-namespace:GeekDesk.Converts"
  10. Background="Transparent"
  11. >
  12. <UserControl.Resources>
  13. <!--<cst:Count2VisibleConvert x:Key="Count2VisibleConvert"/>
  14. <cst:CountGreZero2BoolConvert x:Key="CountGreZero2BoolConvert"/>
  15. <Style x:Key="NoDataStyle" TargetType="TextBlock">
  16. <Style.Triggers>
  17. <DataTrigger Binding="{Binding ElementName=BacklogList, Path=Items.Count, Converter={StaticResource CountGreZero2BoolConvert}}" Value="False">
  18. <Setter Property="Visibility" Value="Visible"/>
  19. </DataTrigger>
  20. <DataTrigger Binding="{Binding ElementName=BacklogList, Path=Items.Count, Converter={StaticResource CountGreZero2BoolConvert}}" Value="True">
  21. <Setter Property="Visibility" Value="Collapsed"/>
  22. </DataTrigger>
  23. </Style.Triggers>
  24. </Style>
  25. <Style x:Key="ToDoStyle" TargetType="DataGrid">
  26. <Style.Triggers>
  27. <DataTrigger Binding="{Binding ElementName=BacklogList, Path=Items.Count, Converter={StaticResource CountGreZero2BoolConvert}}" Value="True">
  28. <Setter Property="Visibility" Value="Visible"/>
  29. </DataTrigger>
  30. <DataTrigger Binding="{Binding ElementName=BacklogList, Path=Items.Count, Converter={StaticResource CountGreZero2BoolConvert}}" Value="False">
  31. <Setter Property="Visibility" Value="Collapsed"/>
  32. </DataTrigger>
  33. </Style.Triggers>
  34. </Style>-->
  35. </UserControl.Resources>
  36. <hc:SimplePanel Margin="20" Background="Transparent">
  37. <Grid Background="Transparent">
  38. <TextBlock x:Name="IsNewToDo" Visibility="Collapsed" />
  39. <TextBlock x:Name="NoData"
  40. VerticalAlignment="Center"
  41. HorizontalAlignment="Center"
  42. TextAlignment="Center"
  43. Text="暂无数据!"
  44. />
  45. <DataGrid x:Name="BacklogList"
  46. HeadersVisibility="All"
  47. AutoGenerateColumns="False"
  48. ItemsSource="{Binding}"
  49. IsReadOnly="True"
  50. Initialized="DataGridMenu_Initialized"
  51. >
  52. <DataGrid.ContextMenu>
  53. <ContextMenu x:Name="Menu" Width="120">
  54. <MenuItem Header="详情" Click="DetailMenu_Click"/>
  55. <MenuItem Header="删除" Click="DeleteMenu_Click"/>
  56. </ContextMenu>
  57. </DataGrid.ContextMenu>
  58. <!--<DataGrid.RowStyle>
  59. <Style TargetType="DataGridRow" BasedOn="{StaticResource DataGridRowStyle}">
  60. <EventSetter Event="MouseRightButtonDown" Handler="DataGridRow_MouseRightButtonDown" />
  61. <Setter Property="Background" Value="White"/>
  62. <Style.Triggers>
  63. <Trigger Property="IsSelected" Value="True">
  64. <Setter Property="Background" Value="{StaticResource BtnBG}"/>
  65. </Trigger>
  66. <Trigger Property="IsSelected" Value="False">
  67. <Setter Property="Background" Value="White"/>
  68. </Trigger>
  69. </Style.Triggers>
  70. </Style>
  71. </DataGrid.RowStyle>-->
  72. <DataGrid.RowStyle>
  73. <Style TargetType="{x:Type DataGridRow}">
  74. <Style.Setters>
  75. <Setter Property="SnapsToDevicePixels" Value="true"/>
  76. <Setter Property="Validation.ErrorTemplate" Value="{x:Null}"/>
  77. <Setter Property="FocusVisualStyle" Value="{x:Null}" />
  78. <Setter Property="Template">
  79. <Setter.Value>
  80. <ControlTemplate TargetType="{x:Type DataGridRow}">
  81. <Border CornerRadius="8" MouseRightButtonDown="DataGridRow_MouseRightButtonDown" Margin="0,0,0,5" BorderBrush="Black" BorderThickness="0" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  82. <Border.Style>
  83. <Style TargetType="Border">
  84. <Setter Property="FocusVisualStyle" Value="{x:Null}" />
  85. </Style>
  86. </Border.Style>
  87. <SelectiveScrollingGrid>
  88. <SelectiveScrollingGrid.ColumnDefinitions>
  89. <ColumnDefinition Width="Auto"/>
  90. <ColumnDefinition Width="*"/>
  91. </SelectiveScrollingGrid.ColumnDefinitions>
  92. <SelectiveScrollingGrid.RowDefinitions>
  93. <RowDefinition Height="*"/>
  94. <RowDefinition Height="Auto"/>
  95. </SelectiveScrollingGrid.RowDefinitions>
  96. <DataGridCellsPresenter Grid.Column="1" ItemsPanel="{TemplateBinding ItemsPanel}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  97. <Path Name="Cross" Grid.ColumnSpan="2" Visibility="Collapsed" Margin="10,0,10,0" Data="M0,0.5 L1,0.5" Stretch="Fill" Stroke="Gray" StrokeThickness="1" Opacity="0.5" />
  98. </SelectiveScrollingGrid>
  99. </Border>
  100. <ControlTemplate.Triggers>
  101. <DataTrigger Binding="{Binding ElementName=IsNewToDo, Path=Text}" Value="N">
  102. <Setter TargetName="Cross" Property="Visibility" Value="Visible"/>
  103. </DataTrigger>
  104. <DataTrigger Binding="{Binding ElementName=IsNewToDo, Path=Text}" Value="Y">
  105. <Setter TargetName="Cross" Property="Visibility" Value="Collapsed"/>
  106. </DataTrigger>
  107. </ControlTemplate.Triggers>
  108. </ControlTemplate>
  109. </Setter.Value>
  110. </Setter>
  111. </Style.Setters>
  112. <Style.Triggers>
  113. <Trigger Property="IsMouseOver" Value="True">
  114. <Setter Property="Background" Value="#E5E5E2" />
  115. </Trigger>
  116. </Style.Triggers>
  117. </Style>
  118. </DataGrid.RowStyle>
  119. <DataGrid.CellStyle>
  120. <Style TargetType="DataGridCell" BasedOn="{StaticResource DataGridCellStyle}">
  121. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  122. <Setter Property="Background" Value="Transparent"/>
  123. <Style.Triggers>
  124. <Trigger Property="IsSelected" Value="True">
  125. <Setter Property="Background" Value="Transparent"/>
  126. <Setter Property="Foreground" Value="Black"/>
  127. </Trigger>
  128. </Style.Triggers>
  129. </Style>
  130. </DataGrid.CellStyle>
  131. <DataGrid.ColumnHeaderStyle>
  132. <Style TargetType="DataGridColumnHeader" BasedOn="{StaticResource DataGridColumnHeaderStyle}">
  133. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  134. </Style>
  135. </DataGrid.ColumnHeaderStyle>
  136. <DataGrid.Background>
  137. <SolidColorBrush Color="Transparent"/>
  138. </DataGrid.Background>
  139. <DataGrid.Columns>
  140. <DataGridTextColumn Width="120" Binding="{Binding Title}" Header="待办任务"/>
  141. <DataGridTextColumn Width="210" Binding="{Binding Msg}" Header="待办详情"/>
  142. <DataGridTextColumn Width="147" Binding="{Binding ExeTime}" Header="待办时间"/>
  143. <DataGridTextColumn Width="147" Binding="{Binding DoneTime}" Header="完成时间"/>
  144. </DataGrid.Columns>
  145. </DataGrid>
  146. <StackPanel hc:Growl.GrowlParent="True" hc:Growl.Token="DeleteConfirm" VerticalAlignment="Center" Margin="0,10,10,50"/>
  147. </Grid>
  148. </hc:SimplePanel>
  149. </UserControl>