TasksByUserControl.xaml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426
  1. <UserControl x:Class="PRSDesktop.TasksByUserControl"
  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:dynamicgrid="clr-namespace:InABox.DynamicGrid;assembly=InABox.Wpf"
  7. xmlns:syncfusion="http://schemas.syncfusion.com/wpf"
  8. xmlns:kanban="clr-namespace:Syncfusion.UI.Xaml.Kanban;assembly=Syncfusion.SfKanban.WPF"
  9. xmlns:local="clr-namespace:PRSDesktop"
  10. mc:Ignorable="d"
  11. d:DesignHeight="450" d:DesignWidth="800">
  12. <UserControl.Resources>
  13. <local:UserTasksHeaderImageConverter x:Key="UserTasksHeaderImageConverter" />
  14. <local:UserTasksHeaderTimeConverter x:Key="UserTasksHeaderTimeConverter" />
  15. <local:BoolToVisibilityConverter x:Key="BoolToVisibilityConverter" />
  16. <!--<local:TaskHeaderWidthConverter x:Key="TaskHeaderWidthConverter"/>-->
  17. <Style x:Key="employeeStyle" TargetType="{x:Type TextBlock}">
  18. <Style.Triggers>
  19. <DataTrigger Binding="{Binding AssignedTo}" Value="">
  20. <Setter Property="Visibility" Value="Collapsed" />
  21. </DataTrigger>
  22. </Style.Triggers>
  23. </Style>
  24. <Style x:Key="managerStyle" TargetType="{x:Type TextBlock}">
  25. <Style.Triggers>
  26. <DataTrigger Binding="{Binding Manager}" Value="">
  27. <Setter Property="Visibility" Value="Collapsed"/>
  28. </DataTrigger>
  29. </Style.Triggers>
  30. </Style>
  31. <Style x:Key="jobStyle" TargetType="{x:Type TextBlock}">
  32. <Style.Triggers>
  33. <DataTrigger Binding="{Binding JobNumber}" Value="">
  34. <Setter Property="Visibility" Value="Collapsed" />
  35. </DataTrigger>
  36. </Style.Triggers>
  37. </Style>
  38. <Style x:Key="descriptionStyle" TargetType="{x:Type TextBlock}">
  39. <Style.Triggers>
  40. <DataTrigger Binding="{Binding Path=Description}" Value="">
  41. <Setter Property="Visibility" Value="Collapsed" />
  42. </DataTrigger>
  43. </Style.Triggers>
  44. </Style>
  45. <Style x:Key="notesStyle" TargetType="{x:Type TextBlock}">
  46. <Style.Triggers>
  47. <DataTrigger Binding="{Binding Path=Notes}" Value="">
  48. <Setter Property="Visibility" Value="Collapsed" />
  49. </DataTrigger>
  50. </Style.Triggers>
  51. </Style>
  52. <DataTemplate x:Key="KanbanHeader">
  53. <!--<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">-->
  54. <Grid>
  55. <Grid.ColumnDefinitions>
  56. <ColumnDefinition Width="Auto" />
  57. <ColumnDefinition Width="*" />
  58. </Grid.ColumnDefinitions>
  59. <Grid.RowDefinitions>
  60. <RowDefinition Height="*" />
  61. <RowDefinition Height="*" />
  62. </Grid.RowDefinitions>
  63. <Border Grid.Column="0" Grid.Row="0" Grid.RowSpan="2" Width="40" Height="40" CornerRadius="20"
  64. Margin="5" BorderBrush="Gray" BorderThickness="0.75" VerticalAlignment="Center"
  65. HorizontalAlignment="Center">
  66. <Border.Background>
  67. <ImageBrush ImageSource="{Binding Converter={StaticResource UserTasksHeaderImageConverter}}"
  68. Stretch="UniformToFill" />
  69. </Border.Background>
  70. </Border>
  71. <TextBlock Grid.Column="1" Grid.Row="0" Text="{Binding Header}" FontSize="16" FontWeight="DemiBold"
  72. HorizontalAlignment="Left" Margin="10,0,10,0" />
  73. <TextBlock Grid.Column="1" Grid.Row="1" FontSize="12" HorizontalAlignment="Left" Margin="10,0,5,0">
  74. <Run Text="{Binding CardCount}" />
  75. <Run Text="Tasks /" />
  76. <Run Text="{Binding Converter={StaticResource UserTasksHeaderTimeConverter}, Mode=OneWay}" />
  77. <Run Text="Hours" />
  78. </TextBlock>
  79. </Grid>
  80. <!--</Border>-->
  81. </DataTemplate>
  82. <DataTemplate x:Key="FullKanban">
  83. <Border BorderBrush="Gray" BorderThickness="0.75" CornerRadius="5" Background="{Binding ColorKey}"
  84. Margin="0,2,0,2" MouseLeftButtonDown="Border_MouseLeftButtonDown" Tag="{Binding}">
  85. <Grid Margin="4">
  86. <Grid.ColumnDefinitions>
  87. <ColumnDefinition x:Name="colCheckbox" Width="Auto" />
  88. <ColumnDefinition x:Name="colDescription" Width="*" />
  89. <ColumnDefinition x:Name="colType" Width="Auto" />
  90. <ColumnDefinition x:Name="colAttach" Width="Auto" />
  91. <ColumnDefinition x:Name="colDueDate" Width="Auto" />
  92. </Grid.ColumnDefinitions>
  93. <Grid.RowDefinitions>
  94. <RowDefinition Height="Auto" />
  95. <RowDefinition Height="*" />
  96. <RowDefinition Height="Auto" />
  97. </Grid.RowDefinitions>
  98. <CheckBox Grid.Row="0" Grid.Column="0" Margin="0,0,4,0" VerticalAlignment="Center"
  99. IsChecked="{Binding Path=Checked}" Checked="CheckBox_Checked"
  100. Unchecked="CheckBox_Checked" Tag="{Binding}" />
  101. <TextBlock Grid.Row="0" Grid.Column="1" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12"
  102. VerticalAlignment="Center" TextTrimming="CharacterEllipsis">
  103. <Run Text="{Binding Path=Number}" /><Run Text=": " /><Run Text="{Binding Path=Title}" />
  104. </TextBlock>
  105. <TextBlock Grid.Row="1" Grid.Column="4" FontSize="12" Margin="4,0,0,0" Text="{Binding Path=Type.Code}"
  106. FontWeight="DemiBold" VerticalAlignment="Center" HorizontalAlignment="Right" />
  107. <Image Grid.Row="0" Grid.Column="3" Margin="4,0,4,0"
  108. Source="pack://application:,,,Resources/attachment.png"
  109. Visibility="{Binding Path=Attachments, Converter={StaticResource BoolToVisibilityConverter}}"
  110. Width="16" Height="16" VerticalAlignment="Center" />
  111. <TextBlock Grid.Row="0" Grid.Column="4" Text="{Binding DueDate, StringFormat='{}{0:dd MMM yy}'}" Margin="5,0,0,0"
  112. FontWeight="Bold" FontSize="12" VerticalAlignment="Center" HorizontalAlignment="Center" />
  113. <TextBlock Grid.Row="1" Grid.Column="0" Grid.ColumnSpan="4" Margin="0,0,0,0" FontSize="12"
  114. HorizontalAlignment="Left" Text="{Binding Path=Description}" VerticalAlignment="Stretch"
  115. TextWrapping="Wrap" />
  116. <DockPanel Grid.Row="2" Grid.Column="0" Grid.ColumnSpan="5">
  117. <TextBlock DockPanel.Dock="Right" x:Name="Job" Margin="0" FontWeight="DemiBold" FontSize="12"
  118. VerticalAlignment="Center" TextAlignment="Right" Style="{StaticResource jobStyle}">
  119. <Run Text="{Binding JobNumber}" /><Run Text=": " /><Run Text="{Binding JobName}" />
  120. </TextBlock>
  121. <TextBlock DockPanel.Dock="Left" x:Name="Staff" FontWeight="DemiBold" FontSize="12"
  122. VerticalAlignment="Center" Text="{Binding AssignedTo}"
  123. Style="{StaticResource employeeStyle}" />
  124. </DockPanel>
  125. </Grid>
  126. <Border.ToolTip>
  127. <Grid>
  128. <Grid.RowDefinitions>
  129. <RowDefinition Height="Auto"/>
  130. <RowDefinition Height="Auto"/>
  131. <RowDefinition Height="Auto"/>
  132. </Grid.RowDefinitions>
  133. <Grid.ColumnDefinitions>
  134. <ColumnDefinition Width="Auto"/>
  135. </Grid.ColumnDefinitions>
  136. <TextBlock Grid.Row="0" Grid.Column="0">
  137. <Run FontWeight="DemiBold" Text="{Binding Path=Title}"/>
  138. </TextBlock>
  139. <TextBlock Grid.Row="1" Grid.Column="0" Style="{StaticResource descriptionStyle}">
  140. <Run Text="{Binding Path=Description}"/>
  141. </TextBlock>
  142. <TextBlock Grid.Row="2" Grid.Column="0" Style="{StaticResource notesStyle}">
  143. <LineBreak/>
  144. <Run Text="{Binding Path=Notes}"/>
  145. </TextBlock>
  146. </Grid>
  147. </Border.ToolTip>
  148. <Border.ContextMenu>
  149. <ContextMenu x:Name="TaskMenu" Tag="{Binding}" Opened="TaskMenu_Opened" />
  150. </Border.ContextMenu>
  151. </Border>
  152. </DataTemplate>
  153. <DataTemplate x:Key="CompactKanban">
  154. <Border BorderBrush="Gray" BorderThickness="0.75" CornerRadius="5" Background="{Binding ColorKey}" Margin="0,2,0,2" MouseLeftButtonDown="Border_MouseLeftButtonDown" Tag="{Binding}">
  155. <DockPanel Margin="4">
  156. <TextBlock DockPanel.Dock="Right" Text="{Binding DueDate, StringFormat='{}{0:dd MMM yy}'}" FontWeight="Bold" FontSize="12" VerticalAlignment="Center" HorizontalAlignment="Center" />
  157. <CheckBox DockPanel.Dock="Left" Margin="0,0,4,0" VerticalAlignment="Center" IsChecked="{Binding Path=Checked}" Checked="CheckBox_Checked" Unchecked="CheckBox_Checked" Tag="{Binding}" />
  158. <TextBlock DockPanel.Dock="Left" x:Name="JobNumber" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource jobStyle}">
  159. <Run Text="{Binding JobNumber}"/><Run Text="/"/>
  160. </TextBlock>
  161. <TextBlock DockPanel.Dock="Left" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center">
  162. <Run Text="{Binding Path=Number}"/><Run Text=": "/>
  163. </TextBlock>
  164. <TextBlock DockPanel.Dock="Left" Margin="0,0,0,0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Text="{Binding Path=Title}" />
  165. <TextBlock DockPanel.Dock="Left" x:Name="Manager" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource managerStyle}">
  166. <Run Text=" ("/><Run Text="{Binding Manager}"/><Run Text=")"/>
  167. </TextBlock>
  168. <TextBlock DockPanel.Dock="Left" x:Name="Employee" Margin="0" FontWeight="DemiBold" FontSize="12" VerticalAlignment="Center" Style="{StaticResource employeeStyle}">
  169. <Run Text=" ("/><Run Text="{Binding AssignedTo}"/><Run Text=")"/>
  170. </TextBlock>
  171. </DockPanel>
  172. <Border.ToolTip>
  173. <Grid>
  174. <Grid.RowDefinitions>
  175. <RowDefinition Height="Auto"/>
  176. <RowDefinition Height="Auto"/>
  177. <RowDefinition Height="Auto"/>
  178. </Grid.RowDefinitions>
  179. <Grid.ColumnDefinitions>
  180. <ColumnDefinition Width="Auto"/>
  181. </Grid.ColumnDefinitions>
  182. <TextBlock Grid.Row="0" Grid.Column="0">
  183. <Run FontWeight="DemiBold" Text="{Binding Path=Title}"/>
  184. </TextBlock>
  185. <TextBlock Grid.Row="1" Grid.Column="0" Style="{StaticResource descriptionStyle}">
  186. <Run Text="{Binding Path=Description}"/>
  187. </TextBlock>
  188. <TextBlock Grid.Row="2" Grid.Column="0" Style="{StaticResource notesStyle}">
  189. <LineBreak/>
  190. <Run Text="{Binding Path=Notes}"/>
  191. </TextBlock>
  192. </Grid>
  193. </Border.ToolTip>
  194. <Border.ContextMenu>
  195. <ContextMenu x:Name="TaskMenu" Tag="{Binding}" Opened="TaskMenu_Opened" />
  196. </Border.ContextMenu>
  197. </Border>
  198. </DataTemplate>
  199. <DataTemplate x:Key="SwimLaneHeaderTemplate">
  200. <Grid>
  201. <Border BorderBrush="Gray" BorderThickness="0.75" Height="0.75" Margin="10,0,15,0"
  202. HorizontalAlignment="Stretch" />
  203. <Border BorderBrush="Gray" BorderThickness="0.75" Margin="0,5,0,0" HorizontalAlignment="Center"
  204. Width="300" Background="WhiteSmoke">
  205. <StackPanel Background="Transparent" x:Name="SwimlaneHeaderPanel" Orientation="Horizontal">
  206. <Grid x:Name="CollapsedIcon" Background="Transparent" Height="30" Width="30">
  207. <Path x:Name="ExpandedPath" IsHitTestVisible="False"
  208. Data="M30.587915,0L31.995998,1.4199842 15.949964,17.351 0,1.4979873 1.4099131,0.078979151 15.949964,14.53102z"
  209. Stretch="Uniform" Fill="#FF000000" Width="14" Height="14" Margin="0,0,0,0"
  210. RenderTransformOrigin="0.5,0.5">
  211. <Path.RenderTransform>
  212. <TransformGroup>
  213. <TransformGroup.Children>
  214. <RotateTransform Angle="0" />
  215. <ScaleTransform ScaleX="1" ScaleY="1" />
  216. </TransformGroup.Children>
  217. </TransformGroup>
  218. </Path.RenderTransform>
  219. </Path>
  220. <Path x:Name="CollapsedPath" Visibility="Collapsed" IsHitTestVisible="False"
  221. Data="M1.4200482,0L17.351001,16.046996 1.4980513,31.996001 0.078979631,30.585997 14.531046,16.046019 0,1.4089964z"
  222. Stretch="Uniform" Fill="#FF000000" Width="14" Height="14" Margin="0,0,0,0"
  223. RenderTransformOrigin="0.5,0.5">
  224. <Path.RenderTransform>
  225. <TransformGroup>
  226. <TransformGroup.Children>
  227. <RotateTransform Angle="0" />
  228. <ScaleTransform ScaleX="1" ScaleY="1" />
  229. </TransformGroup.Children>
  230. </TransformGroup>
  231. </Path.RenderTransform>
  232. </Path>
  233. </Grid>
  234. <TextBlock FontWeight="Medium" IsHitTestVisible="False" FontSize="15" FontStretch="Expanded"
  235. TextWrapping="NoWrap" VerticalAlignment="Center" Text="{Binding Title}"
  236. HorizontalAlignment="Center" TextAlignment="Center" />
  237. </StackPanel>
  238. </Border>
  239. </Grid>
  240. </DataTemplate>
  241. </UserControl.Resources>
  242. <dynamicgrid:DynamicSplitPanel x:Name="SplitPanel" View="Combined" AnchorWidth="100" AllowableViews="Combined"
  243. OnChanged="SplitPanel_OnChanged">
  244. <dynamicgrid:DynamicSplitPanel.Master>
  245. <Grid x:Name="EmployeeGrid" Margin="0" Grid.Column="1" Grid.Row="0">
  246. <Grid.RowDefinitions>
  247. <RowDefinition Height="Auto" />
  248. <RowDefinition x:Name="TeamsRow" Height="200" />
  249. <RowDefinition x:Name="SplitterRow" Height="4" />
  250. <RowDefinition Height="Auto" />
  251. <RowDefinition Height="*" />
  252. </Grid.RowDefinitions>
  253. <Grid.ColumnDefinitions>
  254. <ColumnDefinition Width="*" />
  255. </Grid.ColumnDefinitions>
  256. <Border
  257. Grid.Row="0"
  258. BorderBrush="Gray"
  259. BorderThickness="0.75,0.75,0.75,0"
  260. CornerRadius="5,5,0,0"
  261. Background="WhiteSmoke"
  262. Height="30">
  263. <Label Content="Teams" HorizontalContentAlignment="Center" FontWeight="Bold"
  264. VerticalContentAlignment="Center" />
  265. </Border>
  266. <syncfusion:CheckListBox
  267. Grid.Row="1"
  268. x:Name="SelectedTeams"
  269. DisplayMemberPath="Value"
  270. SelectedValuePath="Key"
  271. IsSelectAllEnabled="False"
  272. IsCheckOnFirstClick="True"
  273. Margin="0"
  274. ItemChecked="SelectedTeams_ItemChecked"
  275. SizeChanged="SelectedTeams_SizeChanged"
  276. VerticalAlignment="Stretch"
  277. BorderBrush="Gray"
  278. BorderThickness="0.75"
  279. Background="White" />
  280. <syncfusion:SfGridSplitter
  281. Grid.Row="2"
  282. x:Name="TeamSplitter"
  283. ResizeBehavior="PreviousAndNext"
  284. Height="4"
  285. HorizontalAlignment="Stretch"
  286. Background="Transparent"
  287. Template="{StaticResource HorizontalSplitter}"
  288. PreviewStyle="{StaticResource HorizontalSplitterPreview}" />
  289. <Border
  290. Grid.Row="3"
  291. BorderBrush="Gray"
  292. BorderThickness="0.75,0.75,0.75,0"
  293. CornerRadius="5,5,0,0"
  294. Background="WhiteSmoke"
  295. Height="30">
  296. <Label Content="Employees" HorizontalContentAlignment="Center" FontWeight="Bold"
  297. VerticalContentAlignment="Center" />
  298. </Border>
  299. <syncfusion:CheckListBox
  300. Grid.Row="4"
  301. x:Name="SelectedEmployees"
  302. DisplayMemberPath="Value"
  303. SelectedValuePath="Key"
  304. IsCheckOnFirstClick="True"
  305. SelectionChanged="EmployeesSelectionChanged"
  306. IsSelectAllEnabled="False"
  307. Background="White"
  308. BorderBrush="Gray"
  309. BorderThickness="0.75"
  310. Margin="0" />
  311. </Grid>
  312. </dynamicgrid:DynamicSplitPanel.Master>
  313. <dynamicgrid:DynamicSplitPanel.Detail>
  314. <Grid>
  315. <Grid.RowDefinitions>
  316. <RowDefinition Height="Auto" />
  317. <RowDefinition Height="*" />
  318. </Grid.RowDefinitions>
  319. <Border
  320. Background="WhiteSmoke"
  321. BorderThickness="0.75,0.75,0.75,0"
  322. BorderBrush="Gray"
  323. CornerRadius="5,5,0,0"
  324. Grid.Row="0"
  325. Height="30"
  326. Padding="2">
  327. <DockPanel>
  328. <Label DockPanel.Dock="Left" Content="Search" Margin="5,0,0,0" />
  329. <Button DockPanel.Dock="Right" x:Name="Export" Padding="10,0" Margin="5,0,0,0" Content="Export"
  330. Click="Export_Click" />
  331. <CheckBox DockPanel.Dock="Right" x:Name="IncludeCompleted" Margin="10,0,5,0"
  332. Content="Include Completed" VerticalAlignment="Center" HorizontalAlignment="Right"
  333. Checked="IncludeCompleted_Checked" Unchecked="IncludeCompleted_Checked" />
  334. <CheckBox DockPanel.Dock="Right" x:Name="IncludeObserved" Margin="10,0,5,0"
  335. Content="Include Observing" VerticalAlignment="Center" HorizontalAlignment="Right"
  336. Checked="IncludeObserved_Checked" Unchecked="IncludeObserved_Checked" />
  337. <CheckBox DockPanel.Dock="Right" x:Name="IncludeManaged" Margin="10,0,5,0"
  338. Content="Include Managed" VerticalAlignment="Center" HorizontalAlignment="Right"
  339. Checked="IncludeManaged_Checked" Unchecked="IncludeManaged_Checked" />
  340. <ComboBox DockPanel.Dock="Right" x:Name="ViewType" Margin="5,0,0,0" Width="100"
  341. SelectedIndex="0" SelectionChanged="ViewType_SelectionChanged"
  342. VerticalContentAlignment="Center">
  343. <ComboBoxItem Content="Full" />
  344. <ComboBoxItem Content="Compact" />
  345. </ComboBox>
  346. <Label DockPanel.Dock="Right" x:Name="ViewTypeLabel" Content="View" Margin="5,0,0,0" />
  347. <ComboBox DockPanel.Dock="Right" x:Name="TaskType" Margin="5,0,0,0" Width="150"
  348. SelectedIndex="0" SelectionChanged="TaskType_SelectionChanged"
  349. VerticalContentAlignment="Center">
  350. </ComboBox>
  351. <Label DockPanel.Dock="Right" x:Name="TaskTypeLabel" Content="Type" Margin="5,0,0,0" />
  352. <TextBox DockPanel.Dock="Left" x:Name="Search" Margin="5,0,0,0" HorizontalAlignment="Stretch"
  353. VerticalContentAlignment="Center" KeyUp="Search_KeyUp" />
  354. </DockPanel>
  355. </Border>
  356. <kanban:SfKanban
  357. SizeChanged="Kanban_SizeChanged"
  358. Grid.Row="1"
  359. Margin="0"
  360. x:Name="Kanban"
  361. HorizontalAlignment="Stretch"
  362. VerticalAlignment="Stretch"
  363. HorizontalContentAlignment="Stretch"
  364. VerticalContentAlignment="Stretch"
  365. AutoGenerateColumns="False"
  366. BorderThickness="0.75"
  367. BorderBrush="Gray"
  368. Background="White"
  369. CardTemplate="{StaticResource FullKanban}"
  370. ColumnHeaderTemplate="{StaticResource KanbanHeader}"
  371. SwimlaneKey="Assignee"
  372. SwimlaneHeaderTemplate="{StaticResource SwimLaneHeaderTemplate}"
  373. CardDragStart="Kanban_CardDragStart"
  374. CardDragEnd="Kanban_CardDragEnd"/>
  375. </Grid>
  376. </dynamicgrid:DynamicSplitPanel.Detail>
  377. </dynamicgrid:DynamicSplitPanel>
  378. </UserControl>