RoleView.xaml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. <UserControl x:Class="MECF.Framework.UI.Client.CenterViews.Configs.Roles.RoleView"
  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:i="http://schemas.microsoft.com/expression/2010/interactivity"
  7. xmlns:micro="clr-namespace:Caliburn.Micro"
  8. xmlns:controls="clr-namespace:OpenSEMI.Ctrlib.Controls"
  9. xmlns:command="clr-namespace:OpenSEMI.ClientBase.Command"
  10. Name="roleCtl"
  11. >
  12. <UserControl.Resources>
  13. <Style BasedOn="{StaticResource ExOnlyVerticalScrollBar}" TargetType="ScrollBar"/>
  14. <Style x:Key="ViewEnabledBtn" TargetType="{x:Type Button}" BasedOn="{StaticResource ResourceKey={x:Type Button}}">
  15. <Setter Property="Button.IsEnabled" Value="False" />
  16. <Style.Triggers>
  17. <MultiDataTrigger>
  18. <MultiDataTrigger.Conditions>
  19. <Condition Binding="{Binding Permission}" Value="3"></Condition>
  20. <Condition Binding="{Binding ControlMode}" Value="VIEW"></Condition>
  21. </MultiDataTrigger.Conditions>
  22. <Setter Property="Button.IsEnabled" Value="True"/>
  23. </MultiDataTrigger>
  24. </Style.Triggers>
  25. </Style>
  26. <Style x:Key="EditEnabledBtn" TargetType="{x:Type Button}" BasedOn="{StaticResource ResourceKey={x:Type Button}}">
  27. <Setter Property="Button.IsEnabled" Value="False" />
  28. <Style.Triggers>
  29. <MultiDataTrigger>
  30. <MultiDataTrigger.Conditions>
  31. <Condition Binding="{Binding Permission}" Value="3"></Condition>
  32. <Condition Binding="{Binding ControlMode}" Value="EDIT"></Condition>
  33. </MultiDataTrigger.Conditions>
  34. <Setter Property="Button.IsEnabled" Value="True"/>
  35. </MultiDataTrigger>
  36. </Style.Triggers>
  37. </Style>
  38. </UserControl.Resources>
  39. <Grid x:Name="MainTable" HorizontalAlignment="Left" Width="{Binding ElementName=roleCtl,Path=ActualWidth}" Height="{Binding ElementName=roleCtl,Path=ActualHeight}">
  40. <Grid x:Name="MainField">
  41. <Grid.ColumnDefinitions>
  42. <ColumnDefinition Width="Auto" MinWidth="250"/>
  43. <ColumnDefinition Width="*"/>
  44. </Grid.ColumnDefinitions>
  45. <Grid.RowDefinitions>
  46. <RowDefinition />
  47. <RowDefinition Height="55"/>
  48. </Grid.RowDefinitions>
  49. <GridSplitter Width="5" Grid.Column="1" HorizontalAlignment="Left" BorderThickness="0,8">
  50. <GridSplitter.Background>
  51. <SolidColorBrush/>
  52. </GridSplitter.Background>
  53. </GridSplitter>
  54. <Border BorderBrush="{DynamicResource Tab_BD}" BorderThickness="1" SnapsToDevicePixels="True" Margin="10,20,0,0" Padding="12">
  55. <TreeView HorizontalAlignment="Left" Name="RolesTree" VerticalAlignment="Top">
  56. <TreeView.Style>
  57. <Style TargetType="{x:Type TreeView}" BasedOn="{StaticResource ResourceKey={x:Type TreeView}}">
  58. <Setter Property="TreeView.IsEnabled" Value="False" />
  59. <Style.Triggers>
  60. <DataTrigger Binding="{Binding ControlMode}" Value="VIEW">
  61. <Setter Property="TreeView.IsEnabled" Value="True"/>
  62. </DataTrigger>
  63. </Style.Triggers>
  64. </Style>
  65. </TreeView.Style>
  66. <TreeViewItem Header="Roles" ItemsSource="{Binding RoleList}" IsExpanded="True">
  67. <TreeViewItem.ItemContainerStyle>
  68. <Style x:Name="RoleTreeViewItem" TargetType="{x:Type TreeViewItem}" BasedOn="{StaticResource ResourceKey={x:Type TreeViewItem}}">
  69. <Setter Property="IsSelected" Value="{Binding Path=IsSelected,Mode=TwoWay}"></Setter>
  70. <Style.Triggers>
  71. <Trigger Property="VirtualizingStackPanel.IsVirtualizing" Value="true">
  72. <Setter Property="ItemsPanel">
  73. <Setter.Value>
  74. <ItemsPanelTemplate>
  75. <VirtualizingStackPanel/>
  76. </ItemsPanelTemplate>
  77. </Setter.Value>
  78. </Setter>
  79. </Trigger>
  80. </Style.Triggers>
  81. </Style>
  82. </TreeViewItem.ItemContainerStyle>
  83. <TreeViewItem.ItemTemplate>
  84. <DataTemplate>
  85. <TextBlock Text="{Binding DisplayRoleName}" FontSize="16" TextAlignment="Center" Padding="5" />
  86. </DataTemplate>
  87. </TreeViewItem.ItemTemplate>
  88. </TreeViewItem>
  89. <command:CommandSource.Trigger>
  90. <command:CommandTriggerGroup>
  91. <command:EventCommandTrigger
  92. RoutedEvent="TreeView.SelectedItemChanged"
  93. CustomParameter="{Binding ElementName=RolesTree,Path=SelectedItem}"
  94. Command="{Binding DataContext.RoleTreeSelectChangedCommand,
  95. RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type UserControl}}}" />
  96. </command:CommandTriggerGroup>
  97. </command:CommandSource.Trigger>
  98. </TreeView>
  99. </Border>
  100. <Grid Grid.Column="1" Margin="10,0,10,10">
  101. <Grid.RowDefinitions>
  102. <RowDefinition Height="20"/>
  103. <RowDefinition Height="Auto"/>
  104. <RowDefinition/>
  105. </Grid.RowDefinitions>
  106. <TextBlock TextWrapping="Wrap" Text="Role Property" VerticalAlignment="Top" Foreground="{DynamicResource FG_Black}" FontWeight="Bold" FontSize="14" FontFamily="Arial" Margin="5,0,0,0"/>
  107. <Grid x:Name="Role_Property" Grid.Row="1" Margin="0,0,0,5" IsEnabled="{Binding IsPermission}">
  108. <Grid.RowDefinitions>
  109. <RowDefinition Height="36"/>
  110. <RowDefinition Height="36"/>
  111. <RowDefinition Height="36"/>
  112. <RowDefinition Height="36"/>
  113. </Grid.RowDefinitions>
  114. <Grid x:Name="Role_Name" Grid.Row="0">
  115. <Grid.ColumnDefinitions>
  116. <ColumnDefinition Width="150"/>
  117. <ColumnDefinition/>
  118. </Grid.ColumnDefinitions>
  119. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  120. <TextBlock Text="Role Name" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  121. </Border>
  122. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  123. <TextBox Text="{Binding TreeSelectedRole.DisplayRoleName,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" HorizontalContentAlignment="Stretch" x:Name="textBox1"
  124. HorizontalAlignment="Left" VerticalAlignment="Center" Width="200" IsEnabled="{Binding IsEnabledRoleName}" Height="33">
  125. <i:Interaction.Triggers>
  126. <i:EventTrigger EventName="TextChanged">
  127. <micro:ActionMessage MethodName="OnRoleChanged">
  128. </micro:ActionMessage>
  129. </i:EventTrigger>
  130. </i:Interaction.Triggers>
  131. </TextBox>
  132. </Border>
  133. </Grid>
  134. <Grid x:Name="Is_Auto_Logout" Grid.Row="1">
  135. <Grid.ColumnDefinitions>
  136. <ColumnDefinition Width="150"/>
  137. <ColumnDefinition/>
  138. </Grid.ColumnDefinitions>
  139. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  140. <TextBlock Text="Is Auto lock" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  141. </Border>
  142. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  143. <CheckBox IsChecked="{Binding TreeSelectedRole.DisplayIsAutoLogout}" HorizontalAlignment="Left" VerticalAlignment="Center"
  144. Content=""
  145. Name="checkBox1">
  146. <i:Interaction.Triggers>
  147. <i:EventTrigger EventName="Click">
  148. <micro:ActionMessage MethodName="OnAutoLogoutTimeChecked">
  149. <micro:Parameter Value="$source" />
  150. </micro:ActionMessage>
  151. </i:EventTrigger>
  152. </i:Interaction.Triggers>
  153. </CheckBox>
  154. </Border>
  155. </Grid>
  156. <Grid x:Name="Time" Grid.Row="2">
  157. <Grid.ColumnDefinitions>
  158. <ColumnDefinition Width="150"/>
  159. <ColumnDefinition/>
  160. </Grid.ColumnDefinitions>
  161. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  162. <TextBlock Text="Time(minutes)" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  163. </Border>
  164. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  165. <controls:TextBoxEx EditBoxMode="UnSignInteger" Text="{Binding TreeSelectedRole.DisplayAutoLogoutTime,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" HorizontalContentAlignment="Stretch" TextSaved="{Binding Mode=TwoWay, Path=TreeSelectedRole.TimeTextSaved }" x:Name="textBox2"
  166. HorizontalAlignment="Left" VerticalAlignment="Center" Width="200" PreviewTextInput="TextBox2_PreviewTextInput" Height="34">
  167. <i:Interaction.Triggers>
  168. <i:EventTrigger EventName="TextChanged">
  169. <micro:ActionMessage MethodName="OnRoleChanged">
  170. </micro:ActionMessage>
  171. </i:EventTrigger>
  172. </i:Interaction.Triggers>
  173. </controls:TextBoxEx>
  174. </Border>
  175. </Grid>
  176. <Grid x:Name="Description" Grid.Row="3">
  177. <Grid.ColumnDefinitions>
  178. <ColumnDefinition Width="150"/>
  179. <ColumnDefinition/>
  180. </Grid.ColumnDefinitions>
  181. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  182. <TextBlock Text="Description" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  183. </Border>
  184. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  185. <TextBox Text="{Binding TreeSelectedRole.DisplayDescription,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" HorizontalContentAlignment="Stretch" x:Name="textBox3"
  186. HorizontalAlignment="Left" VerticalAlignment="Center" MinWidth="200" Height="34">
  187. <i:Interaction.Triggers>
  188. <i:EventTrigger EventName="TextChanged">
  189. <micro:ActionMessage MethodName="OnRoleChanged">
  190. </micro:ActionMessage>
  191. </i:EventTrigger>
  192. </i:Interaction.Triggers>
  193. </TextBox>
  194. </Border>
  195. </Grid>
  196. </Grid>
  197. <TabControl Grid.Row="2" HorizontalContentAlignment="Left">
  198. <TabItem>
  199. <TabItem.Header>
  200. <TextBlock Text="Page Access Permission" FontWeight="Bold"/>
  201. </TabItem.Header>
  202. <ListView AlternationCount="2"
  203. VerticalAlignment="Top"
  204. x:Name="RolesList"
  205. ScrollViewer.HorizontalScrollBarVisibility="Visible"
  206. ScrollViewer.VerticalScrollBarVisibility="Visible"
  207. ScrollViewer.CanContentScroll="True"
  208. ItemsSource="{Binding Path=TreeSelectedRole.MenuCollection}" IsEnabled="{Binding IsPermission}">
  209. <ListView.ItemsPanel>
  210. <ItemsPanelTemplate>
  211. <UniformGrid Columns="2"></UniformGrid>
  212. </ItemsPanelTemplate>
  213. </ListView.ItemsPanel>
  214. <ListView.View>
  215. <GridView>
  216. <GridViewColumn Width="200">
  217. <GridViewColumn.CellTemplate>
  218. <DataTemplate>
  219. <Button Content="{Binding Name}" Width="180" Height="45" HorizontalContentAlignment="Center" Margin="0,2,0,2" VerticalContentAlignment="Center">
  220. <i:Interaction.Triggers>
  221. <i:EventTrigger EventName="Click">
  222. <micro:ActionMessage MethodName="SelectRolePermission">
  223. <micro:Parameter Value="{Binding}"></micro:Parameter>
  224. </micro:ActionMessage>
  225. </i:EventTrigger>
  226. </i:Interaction.Triggers>
  227. </Button>
  228. </DataTemplate>
  229. </GridViewColumn.CellTemplate>
  230. </GridViewColumn>
  231. <GridViewColumn Width="150" >
  232. <GridViewColumn.CellTemplate>
  233. <DataTemplate >
  234. <TextBlock Text="{Binding StringPermission}" TextAlignment="Center" Width="150" >
  235. </TextBlock>
  236. </DataTemplate>
  237. </GridViewColumn.CellTemplate>
  238. </GridViewColumn>
  239. </GridView>
  240. </ListView.View>
  241. </ListView>
  242. </TabItem>
  243. </TabControl>
  244. </Grid>
  245. <StackPanel Grid.Row="1" Orientation="Horizontal" VerticalAlignment="Center" HorizontalAlignment="Right" Grid.Column="1" Margin="0,6,10,6">
  246. <Button Content="Create" Style="{StaticResource ViewEnabledBtn}" Command="{Binding btnAddRoleCommand}" Height="40" Width="80"/>
  247. <Button Content="Delete" Style="{StaticResource ViewEnabledBtn}" Command="{Binding btnDeleteRoleCommand}" Height="40" Width="80" Margin="10,0,0,0"/>
  248. <Button Content="Clone" Style="{StaticResource ViewEnabledBtn}" Command="{Binding btnCloneRoleCommand}" Height="40" Width="80" Margin="10,0,0,0"/>
  249. <Button Content="Save" Style="{StaticResource EditEnabledBtn}" Command="{Binding btnSaveCommand}" Height="40" Width="80" Margin="10,0,0,0" />
  250. <Button Content="Cancel" Style="{StaticResource EditEnabledBtn}" Command="{Binding BtnCancelRoleCommand}" Height="40" Width="80" Margin="10,0,0,0"/>
  251. </StackPanel>
  252. </Grid>
  253. </Grid>
  254. </UserControl>