TasksByStatusControl.xaml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. <UserControl
  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:PRSDesktop"
  7. xmlns:Kanban="clr-namespace:Syncfusion.UI.Xaml.Kanban;assembly=Syncfusion.SfKanban.WPF"
  8. x:Class="PRSDesktop.TasksByStatusControl"
  9. mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="400">
  10. <UserControl.Resources>
  11. <local:StatusTasksHeaderTimeConverter x:Key="StatusTasksHeaderTimeConverter" />
  12. <local:BoolToVisibilityConverter x:Key="BoolToVisibilityConverter" />
  13. <Style x:Key="employeeStyle" TargetType="{x:Type TextBlock}">
  14. <Style.Triggers>
  15. <DataTrigger Binding="{Binding AssignedTo}" Value="">
  16. <Setter Property="Visibility" Value="Collapsed" />
  17. </DataTrigger>
  18. </Style.Triggers>
  19. </Style>
  20. <Style x:Key="managerStyle" TargetType="{x:Type TextBlock}">
  21. <Style.Triggers>
  22. <DataTrigger Binding="{Binding Manager}" Value="">
  23. <Setter Property="Visibility" Value="Collapsed"/>
  24. </DataTrigger>
  25. </Style.Triggers>
  26. </Style>
  27. <Style x:Key="jobStyle" TargetType="{x:Type TextBlock}">
  28. <Style.Triggers>
  29. <DataTrigger Binding="{Binding JobNumber}" Value="">
  30. <Setter Property="Visibility" Value="Collapsed" />
  31. </DataTrigger>
  32. </Style.Triggers>
  33. </Style>
  34. <Style x:Key="descriptionStyle" TargetType="{x:Type TextBlock}">
  35. <Style.Triggers>
  36. <DataTrigger Binding="{Binding Path=Description}" Value="">
  37. <Setter Property="Visibility" Value="Collapsed" />
  38. </DataTrigger>
  39. </Style.Triggers>
  40. </Style>
  41. <Style x:Key="notesStyle" TargetType="{x:Type TextBlock}">
  42. <Style.Triggers>
  43. <DataTrigger Binding="{Binding Path=Notes}" Value="">
  44. <Setter Property="Visibility" Value="Collapsed" />
  45. </DataTrigger>
  46. </Style.Triggers>
  47. </Style>
  48. <DataTemplate x:Key="KanbanHeader">
  49. <!--<Border BorderThickness="0.75" BorderBrush="Gray" CornerRadius="5,5,0,0" Margin="0,10,0,0" Padding="5" Width="{Binding Converter={StaticResource TaskHeaderWidthConverter}}" Background="WhiteSmoke">-->
  50. <StackPanel Orientation="Vertical">
  51. <TextBlock Text="{Binding Header}" FontSize="16" FontWeight="DemiBold" HorizontalAlignment="Left"
  52. Margin="10,0,10,0" />
  53. <TextBlock FontSize="12" HorizontalAlignment="Left" Margin="10,0,5,0">
  54. <Run Text="{Binding CardCount}" />
  55. <Run Text="Tasks /" />
  56. <Run Text="{Binding Converter={StaticResource StatusTasksHeaderTimeConverter}, Mode=OneWay}" />
  57. <Run Text="Hours" />
  58. </TextBlock>
  59. </StackPanel>
  60. <!--</Border>-->
  61. </DataTemplate>
  62. <DataTemplate x:Key="FullKanban">
  63. <Border BorderBrush="Gray" BorderThickness="0.75" CornerRadius="5" Background="{Binding ColorKey}"
  64. Margin="0,2,0,2" MouseLeftButtonDown="Border_MouseLeftButtonDown" Tag="{Binding}">
  65. <Grid Margin="4">
  66. <Grid.ColumnDefinitions>
  67. <ColumnDefinition x:Name="colImage" Width="Auto" />
  68. <ColumnDefinition x:Name="colCheckbox" Width="Auto" />
  69. <ColumnDefinition x:Name="colDescription" Width="*" />
  70. <ColumnDefinition x:Name="colType" Width="Auto" />
  71. <ColumnDefinition x:Name="colAttach" Width="Auto" />
  72. <ColumnDefinition x:Name="colDueDate" Width="Auto" />
  73. </Grid.ColumnDefinitions>
  74. <Grid.RowDefinitions>
  75. <RowDefinition Height="Auto" />
  76. <RowDefinition Height="*" />
  77. <RowDefinition Height="Auto" />
  78. </Grid.RowDefinitions>
  79. <Border Grid.Column="0" Grid.Row="0" Grid.RowSpan="2" Width="40" Height="40" CornerRadius="20"
  80. Margin="0,0,4,0" BorderBrush="Black" BorderThickness="1" VerticalAlignment="Top">
  81. <Border.Background>
  82. <ImageBrush ImageSource="{Binding Path=Image}" Stretch="UniformToFill" />
  83. </Border.Background>
  84. </Border>
  85. <CheckBox Grid.Row="0" Grid.Column="1" Margin="0,0,4,0" VerticalAlignment="Center"
  86. IsChecked="{Binding Path=Checked}" Checked="CheckBox_Checked"
  87. Unchecked="CheckBox_Checked" Tag="{Binding}" />
  88. <TextBlock Grid.Row="0" Grid.Column="2" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12"
  89. VerticalAlignment="Center">
  90. <Run Text="{Binding Path=Number}" /><Run Text=": " /><Run Text="{Binding Path=Title}" />
  91. </TextBlock>
  92. <TextBlock Grid.Row="0" Grid.Column="3" FontSize="12" Margin="4,0,0,0" Text="{Binding Path=Type.Code}"
  93. FontWeight="DemiBold" VerticalAlignment="Center" HorizontalAlignment="Center" />
  94. <Image Grid.Row="0" Grid.Column="4" Margin="4,0,4,0"
  95. Source="pack://application:,,,Resources/attachment.png"
  96. Visibility="{Binding Path=Attachments, Converter={StaticResource BoolToVisibilityConverter}}"
  97. Width="16" Height="16" VerticalAlignment="Center" />
  98. <TextBlock Grid.Row="0" Grid.Column="5" Text="{Binding DueDate, StringFormat='{}{0:dd MMM yy}'}"
  99. FontWeight="Bold" FontSize="12" VerticalAlignment="Center" HorizontalAlignment="Center" />
  100. <TextBlock Grid.Row="1" Grid.Column="1" Grid.ColumnSpan="5" Margin="0,0,0,0" FontSize="12"
  101. HorizontalAlignment="Left" Text="{Binding Path=Description}" VerticalAlignment="Stretch"
  102. TextWrapping="Wrap" />
  103. <DockPanel Grid.Row="2" Grid.Column="1" Grid.ColumnSpan="5">
  104. <TextBlock DockPanel.Dock="Right" x:Name="Job" Margin="0" FontWeight="DemiBold" FontSize="12"
  105. VerticalAlignment="Center" TextAlignment="Right" Style="{StaticResource jobStyle}">
  106. <Run Text="{Binding JobNumber}" /><Run Text=": " /><Run Text="{Binding JobName}" />
  107. </TextBlock>
  108. <TextBlock DockPanel.Dock="Left" x:Name="Staff" FontWeight="DemiBold" FontSize="12"
  109. VerticalAlignment="Center" Text="{Binding AssignedTo}"
  110. Style="{StaticResource employeeStyle}" />
  111. </DockPanel>
  112. <Image Grid.Row="2" Grid.Column="0" Margin="0,0,4,0"
  113. Source="pack://application:,,,Resources/lock.png"
  114. Visibility="{Binding Path=Locked, Converter={StaticResource BoolToVisibilityConverter}}"
  115. Width="20" Height="20" VerticalAlignment="Center" HorizontalAlignment="Center" />
  116. </Grid>
  117. <Border.ToolTip>
  118. <Grid>
  119. <Grid.RowDefinitions>
  120. <RowDefinition Height="Auto"/>
  121. <RowDefinition Height="Auto"/>
  122. <RowDefinition Height="Auto"/>
  123. </Grid.RowDefinitions>
  124. <Grid.ColumnDefinitions>
  125. <ColumnDefinition Width="Auto"/>
  126. </Grid.ColumnDefinitions>
  127. <TextBlock Grid.Row="0" Grid.Column="0">
  128. <Run FontWeight="DemiBold" Text="{Binding Path=Title}"/>
  129. </TextBlock>
  130. <TextBlock Grid.Row="1" Grid.Column="0" Style="{StaticResource descriptionStyle}">
  131. <Run Text="{Binding Path=Description}"/>
  132. </TextBlock>
  133. <TextBlock Grid.Row="2" Grid.Column="0" Style="{StaticResource notesStyle}">
  134. <LineBreak/>
  135. <Run Text="{Binding Path=Notes}"/>
  136. </TextBlock>
  137. </Grid>
  138. </Border.ToolTip>
  139. <Border.ContextMenu>
  140. <ContextMenu x:Name="TaskMenu" Tag="{Binding}" Opened="TaskMenu_Opened" />
  141. </Border.ContextMenu>
  142. </Border>
  143. </DataTemplate>
  144. <DataTemplate x:Key="CompactKanban">
  145. <Border BorderBrush="Gray" BorderThickness="0.75" CornerRadius="5" Background="{Binding ColorKey}" Margin="0,2,0,2" MouseLeftButtonDown="Border_MouseLeftButtonDown" Tag="{Binding}">
  146. <DockPanel Margin="4">
  147. <TextBlock DockPanel.Dock="Right" Text="{Binding DueDate, StringFormat='{}{0:dd MMM yy}'}" FontWeight="Bold" FontSize="12" VerticalAlignment="Center" HorizontalAlignment="Center" />
  148. <CheckBox DockPanel.Dock="Left" Margin="0,0,4,0" VerticalAlignment="Center" IsChecked="{Binding Path=Checked}" Checked="CheckBox_Checked" Unchecked="CheckBox_Checked" Tag="{Binding}" />
  149. <TextBlock DockPanel.Dock="Left" x:Name="JobNumber" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource jobStyle}">
  150. <Run Text="{Binding JobNumber}"/><Run Text="/"/>
  151. </TextBlock>
  152. <TextBlock DockPanel.Dock="Left" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center">
  153. <Run Text="{Binding Path=Number}"/><Run Text=": "/>
  154. </TextBlock>
  155. <TextBlock DockPanel.Dock="Left" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Text="{Binding Path=Title}" />
  156. <TextBlock DockPanel.Dock="Left" x:Name="Manager" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource managerStyle}">
  157. <Run Text=" ("/><Run Text="{Binding Manager}"/><Run Text=")"/>
  158. </TextBlock>
  159. <TextBlock DockPanel.Dock="Left" x:Name="Employee" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource employeeStyle}">
  160. <Run Text=" ("/><Run Text="{Binding AssignedTo}"/><Run Text=")"/>
  161. </TextBlock>
  162. </DockPanel>
  163. <Border.ToolTip>
  164. <Grid>
  165. <Grid.RowDefinitions>
  166. <RowDefinition Height="Auto"/>
  167. <RowDefinition Height="Auto"/>
  168. <RowDefinition Height="Auto"/>
  169. </Grid.RowDefinitions>
  170. <Grid.ColumnDefinitions>
  171. <ColumnDefinition Width="Auto"/>
  172. </Grid.ColumnDefinitions>
  173. <TextBlock Grid.Row="0" Grid.Column="0">
  174. <Run FontWeight="DemiBold" Text="{Binding Path=Title}"/>
  175. </TextBlock>
  176. <TextBlock Grid.Row="1" Grid.Column="0" Style="{StaticResource descriptionStyle}">
  177. <Run Text="{Binding Path=Description}"/>
  178. </TextBlock>
  179. <TextBlock Grid.Row="2" Grid.Column="0" Style="{StaticResource notesStyle}">
  180. <LineBreak/>
  181. <Run Text="{Binding Path=Notes}"/>
  182. </TextBlock>
  183. </Grid>
  184. </Border.ToolTip>
  185. <Border.ContextMenu>
  186. <ContextMenu x:Name="TaskMenu" Tag="{Binding}" Opened="TaskMenu_Opened" />
  187. </Border.ContextMenu>
  188. </Border>
  189. </DataTemplate>
  190. </UserControl.Resources>
  191. <Grid>
  192. <Grid.ColumnDefinitions>
  193. <ColumnDefinition Width="Auto" x:Name="EmployeeListColumn" />
  194. <ColumnDefinition Width="*" />
  195. </Grid.ColumnDefinitions>
  196. <Grid.RowDefinitions>
  197. <RowDefinition Height="Auto" />
  198. <RowDefinition Height="*" />
  199. </Grid.RowDefinitions>
  200. <Border Grid.Row="0" Grid.Column="0" CornerRadius="5,5,0,0" BorderBrush="Gray" BorderThickness="0.75"
  201. Background="WhiteSmoke" Padding="5" Margin="0,0,4,2">
  202. <Label Content="Employee List" HorizontalContentAlignment="Center" />
  203. </Border>
  204. <ListView Grid.Column="0" Grid.Row="1" x:Name="Employees" HorizontalAlignment="Stretch"
  205. SelectionChanged="Employees_SelectionChanged" Margin="0,0,4,0" Background="White" BorderBrush="Gray"
  206. BorderThickness="0.75">
  207. <ListView.ItemTemplate>
  208. <DataTemplate>
  209. <Grid HorizontalAlignment="Stretch" Margin="4,2,4,2">
  210. <StackPanel Orientation="Horizontal" HorizontalAlignment="Stretch">
  211. <Border Width="40" Height="40" CornerRadius="20" BorderBrush="Black" BorderThickness="1"
  212. VerticalAlignment="Center" HorizontalAlignment="Center">
  213. <Border.Background>
  214. <ImageBrush ImageSource="{Binding Path=Image}" Stretch="UniformToFill" />
  215. </Border.Background>
  216. </Border>
  217. <TextBlock x:Name="PCName" Height="Auto" TextWrapping="Wrap" Width="80" Margin="4,0,0,0"
  218. TextAlignment="Left" Text="{Binding Name}" VerticalAlignment="Center" />
  219. </StackPanel>
  220. </Grid>
  221. </DataTemplate>
  222. </ListView.ItemTemplate>
  223. </ListView>
  224. <Border Grid.Row="0" Grid.Column="1" CornerRadius="5,5,0,0" BorderBrush="Gray" BorderThickness="0.75"
  225. Background="WhiteSmoke" Padding="5" Margin="0,0,0,2">
  226. <DockPanel>
  227. <Button DockPanel.Dock="Left" x:Name="TaskTypesLabel" Content="Filter" Padding="4,0" Click="TaskTypesLabel_OnClick" />
  228. <ComboBox DockPanel.Dock="Left" x:Name="TaskTypes" Margin="5,0,0,0" Width="150" SelectedIndex="0"
  229. SelectionChanged="TaskTypes_SelectionChanged" VerticalContentAlignment="Center"
  230. SelectedValuePath="Key" DisplayMemberPath="Value" />
  231. <Button DockPanel.Dock="Left" x:Name="JobFilterBtn" Content="Filter Job" Padding="4,0" Margin="5,0,0,0" Click="JobFilterBtn_OnClick" />
  232. <Label DockPanel.Dock="Left" Content="Search" Margin="5,0,0,0" />
  233. <Button DockPanel.Dock="Right" x:Name="Export" Padding="10,0" Margin="5,0,0,0" Content="Export"
  234. Click="Export_Click" />
  235. <CheckBox DockPanel.Dock="Right" x:Name="IncludeCompleted" Margin="10,0,5,0"
  236. Content="Include Completed" VerticalAlignment="Center" HorizontalAlignment="Right"
  237. Checked="IncludeCompleted_Checked" Unchecked="IncludeCompleted_Checked" />
  238. <CheckBox DockPanel.Dock="Right" x:Name="IncludeObserved" Margin="10,0,5,0" Content="Include Observing"
  239. VerticalAlignment="Center" HorizontalAlignment="Right" Checked="IncludeObserved_Checked"
  240. Unchecked="IncludeObserved_Checked" />
  241. <CheckBox DockPanel.Dock="Right" x:Name="IncludeLocked" Margin="10,0,5,0" Content="Include Locked"
  242. VerticalAlignment="Center" HorizontalAlignment="Right" Checked="IncludeLocked_Checked"
  243. Unchecked="IncludeLocked_Checked" />
  244. <ComboBox DockPanel.Dock="Right" x:Name="ViewType" Margin="5,0,0,0" Width="100" SelectedIndex="0"
  245. SelectionChanged="ViewType_SelectionChanged" VerticalContentAlignment="Center">
  246. <ComboBoxItem Content="Full" />
  247. <ComboBoxItem Content="Compact" />
  248. </ComboBox>
  249. <Label DockPanel.Dock="Right" x:Name="ViewTypeLabel" Content="View" Margin="5,0,0,0" />
  250. <TextBox DockPanel.Dock="Left" x:Name="Search" Margin="5,0,0,0" HorizontalAlignment="Stretch"
  251. VerticalContentAlignment="Center" KeyUp="Search_KeyUp" />
  252. </DockPanel>
  253. </Border>
  254. <Kanban:SfKanban
  255. x:Name="Kanban"
  256. Grid.Column="1"
  257. Grid.Row="1"
  258. Margin="0"
  259. HorizontalAlignment="Stretch"
  260. VerticalAlignment="Stretch"
  261. HorizontalContentAlignment="Stretch"
  262. VerticalContentAlignment="Stretch"
  263. AutoGenerateColumns="False"
  264. BorderBrush="Gray"
  265. BorderThickness="0.75"
  266. Background="WhiteSmoke"
  267. CardTemplate="{StaticResource FullKanban}"
  268. ColumnHeaderTemplate="{StaticResource KanbanHeader}"
  269. SizeChanged="Kanban_SizeChanged"
  270. CardDragStart="Kanban_CardDragStart"
  271. CardDragEnd="Kanban_CardDragEnd" />
  272. </Grid>
  273. </UserControl>