AccountView.xaml 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. <UserControl x:Class="MECF.Framework.UI.Client.CenterViews.Configs.Accounts.AccountView"
  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:controls="clr-namespace:OpenSEMI.Ctrlib.Controls"
  8. xmlns:micro="clr-namespace:Caliburn.Micro"
  9. Name="accountCtl">
  10. <UserControl.Resources>
  11. <Style x:Key="ViewEnabledBtn" TargetType="{x:Type Button}" BasedOn="{StaticResource ResourceKey={x:Type Button}}">
  12. <Setter Property="Button.IsEnabled" Value="False" />
  13. <Style.Triggers>
  14. <MultiDataTrigger>
  15. <MultiDataTrigger.Conditions>
  16. <Condition Binding="{Binding Permission}" Value="3"></Condition>
  17. <Condition Binding="{Binding ControlMode}" Value="VIEW"></Condition>
  18. </MultiDataTrigger.Conditions>
  19. <Setter Property="Button.IsEnabled" Value="True"/>
  20. </MultiDataTrigger>
  21. </Style.Triggers>
  22. </Style>
  23. <Style x:Key="EditEnabledBtn" TargetType="{x:Type Button}" BasedOn="{StaticResource ResourceKey={x:Type Button}}">
  24. <Setter Property="Button.IsEnabled" Value="False" />
  25. <Style.Triggers>
  26. <MultiDataTrigger>
  27. <MultiDataTrigger.Conditions>
  28. <Condition Binding="{Binding Permission}" Value="3"></Condition>
  29. <Condition Binding="{Binding ControlMode}" Value="EDIT"></Condition>
  30. </MultiDataTrigger.Conditions>
  31. <Setter Property="Button.IsEnabled" Value="True"/>
  32. </MultiDataTrigger>
  33. </Style.Triggers>
  34. </Style>
  35. </UserControl.Resources>
  36. <Grid x:Name="MainTable" HorizontalAlignment="Left" Width="{Binding ElementName=accountCtl, Path=ActualWidth}" Height="{Binding ElementName=accountCtl,Path=ActualHeight}">
  37. <Grid x:Name="MainField">
  38. <Grid.ColumnDefinitions>
  39. <ColumnDefinition Width="250"/>
  40. <ColumnDefinition />
  41. </Grid.ColumnDefinitions>
  42. <Grid.RowDefinitions>
  43. <RowDefinition />
  44. <RowDefinition Height="40"/>
  45. </Grid.RowDefinitions>
  46. <GridSplitter Width="5" Grid.Column="1" HorizontalAlignment="Left" BorderThickness="0,8">
  47. <GridSplitter.Background>
  48. <SolidColorBrush/>
  49. </GridSplitter.Background>
  50. </GridSplitter>
  51. <ListView Name="AccountList" AlternationCount="2" Margin="10,20,0,0" ItemsSource="{Binding AccountList}" SelectedItem="{Binding TreeSelectedAccount}" >
  52. <ListView.Style>
  53. <Style TargetType="{x:Type ListView}" BasedOn="{StaticResource ResourceKey={x:Type ListView}}">
  54. <Setter Property="ListView.IsEnabled" Value="False"/>
  55. <Style.Triggers>
  56. <DataTrigger Binding="{Binding ControlMode}" Value="VIEW">
  57. <Setter Property="ListView.IsEnabled" Value="True"/>
  58. </DataTrigger>
  59. </Style.Triggers>
  60. </Style>
  61. </ListView.Style>
  62. <ListView.View>
  63. <GridView>
  64. <GridView.Columns>
  65. <GridViewColumn Header="Account" Width="200">
  66. <GridViewColumn.CellTemplate>
  67. <DataTemplate>
  68. <TextBlock Text="{Binding DisplayAccountName}" Height="30" VerticalAlignment="Center" TextAlignment="Center"></TextBlock>
  69. </DataTemplate>
  70. </GridViewColumn.CellTemplate>
  71. </GridViewColumn>
  72. </GridView.Columns>
  73. </GridView>
  74. </ListView.View>
  75. </ListView>
  76. <Grid Margin="10,0,0,0" Grid.Column="1">
  77. <Grid.RowDefinitions>
  78. <RowDefinition Height="20"/>
  79. <RowDefinition Height="Auto"/>
  80. <RowDefinition/>
  81. </Grid.RowDefinitions>
  82. <TextBlock TextWrapping="Wrap" Text="Account Property" HorizontalAlignment="Left" VerticalAlignment="Top" Foreground="{DynamicResource FG_Black}" FontSize="14" FontWeight="Bold" FontFamily="Arial" Margin="5,0"/>
  83. <Grid Grid.Row="1" IsEnabled="{Binding IsPermission}" Margin="0,0,10,0">
  84. <Grid.RowDefinitions>
  85. <RowDefinition Height="36"/>
  86. <RowDefinition Height="36"/>
  87. <RowDefinition Height="36"/>
  88. <RowDefinition Height="36"/>
  89. <RowDefinition/>
  90. </Grid.RowDefinitions>
  91. <Grid x:Name="GdAccountName" Grid.Row="0">
  92. <Grid.ColumnDefinitions>
  93. <ColumnDefinition Width="150"/>
  94. <ColumnDefinition/>
  95. </Grid.ColumnDefinitions>
  96. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  97. <TextBlock Text="Login Name" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  98. </Border>
  99. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  100. <TextBox Text="{Binding TreeSelectedAccount.DisplayAccountName,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,ValidatesOnDataErrors=True}" Validation.ErrorTemplate="{StaticResource ValidationTemplate}" HorizontalContentAlignment="Left" x:Name="TbAccountName"
  101. IsEnabled="{Binding Mode=TwoWay, Path=TreeSelectedAccount.IsEnableChangeAccountName }"
  102. HorizontalAlignment="Left" VerticalAlignment="Stretch" MaxLength="50" Width="200">
  103. <i:Interaction.Triggers>
  104. <i:EventTrigger EventName="TextChanged">
  105. <micro:ActionMessage MethodName="OnAccountChanged">
  106. </micro:ActionMessage>
  107. </i:EventTrigger>
  108. </i:Interaction.Triggers>
  109. </TextBox>
  110. </Border>
  111. </Grid>
  112. <Grid x:Name="GdNewPassword" Grid.Row="1">
  113. <Grid.ColumnDefinitions>
  114. <ColumnDefinition Width="150"/>
  115. <ColumnDefinition/>
  116. </Grid.ColumnDefinitions>
  117. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  118. <TextBlock Text="New Password" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  119. </Border>
  120. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  121. <PasswordBox Name="pwNewPassword" HorizontalAlignment="Left" MaxLength="50" Width="200">
  122. <i:Interaction.Triggers>
  123. <i:EventTrigger EventName="PreviewMouseUp">
  124. <micro:ActionMessage MethodName="PasswordMouseLeftButtonUp">
  125. <micro:Parameter Value="$source" />
  126. <micro:Parameter Value="$eventargs" />
  127. </micro:ActionMessage>
  128. </i:EventTrigger>
  129. <i:EventTrigger EventName="PasswordChanged">
  130. <micro:ActionMessage MethodName="OnAccountChanged">
  131. </micro:ActionMessage>
  132. </i:EventTrigger>
  133. </i:Interaction.Triggers>
  134. </PasswordBox>
  135. </Border>
  136. </Grid>
  137. <Grid x:Name="GdConfirmPassword" Grid.Row="2">
  138. <Grid.ColumnDefinitions>
  139. <ColumnDefinition Width="150"/>
  140. <ColumnDefinition/>
  141. </Grid.ColumnDefinitions>
  142. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  143. <TextBlock Text="Confirm Password" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  144. </Border>
  145. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  146. <PasswordBox Name="pwConfirmPassword" HorizontalAlignment="Left" MaxLength="50" Width="200">
  147. <i:Interaction.Triggers>
  148. <i:EventTrigger EventName="PreviewMouseUp">
  149. <micro:ActionMessage MethodName="PasswordMouseLeftButtonUp">
  150. <micro:Parameter Value="$source" />
  151. <micro:Parameter Value="$eventargs" />
  152. </micro:ActionMessage>
  153. </i:EventTrigger>
  154. <i:EventTrigger EventName="PasswordChanged">
  155. <micro:ActionMessage MethodName="OnAccountChanged">
  156. </micro:ActionMessage>
  157. </i:EventTrigger>
  158. </i:Interaction.Triggers>
  159. </PasswordBox>
  160. </Border>
  161. </Grid>
  162. <!--<Grid x:Name="GdFirstName" Grid.Row="3">
  163. <Grid.ColumnDefinitions>
  164. <ColumnDefinition Width="120"/>
  165. <ColumnDefinition/>
  166. </Grid.ColumnDefinitions>
  167. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  168. <TextBlock Text="First Name" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="12" FontFamily="Arial" VerticalAlignment="Center"/>
  169. </Border>
  170. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  171. <controls:TextBoxEx Text="{Binding TreeSelectedAccount.DisplayFirstName,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,ValidatesOnDataErrors=True}" Validation.ErrorTemplate="{StaticResource ValidationTemplate}" HorizontalContentAlignment="Stretch" TextSaved="{Binding Mode=TwoWay, Path=TreeSelectedAccount.FirstNameTextSaved }" x:Name="TbFirstName"
  172. HorizontalAlignment="Left" VerticalAlignment="Top" MaxLength="50" Width="200">
  173. <i:Interaction.Triggers>
  174. <i:EventTrigger EventName="TextChanged">
  175. <micro:ActionMessage MethodName="OnAccountChanged">
  176. </micro:ActionMessage>
  177. </i:EventTrigger>
  178. </i:Interaction.Triggers>
  179. </controls:TextBoxEx>
  180. </Border>
  181. </Grid>
  182. <Grid x:Name="GdLastName" Grid.Row="4">
  183. <Grid.ColumnDefinitions>
  184. <ColumnDefinition Width="120"/>
  185. <ColumnDefinition/>
  186. </Grid.ColumnDefinitions>
  187. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  188. <TextBlock Text="Last Name" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="12" FontFamily="Arial" VerticalAlignment="Center"/>
  189. </Border>
  190. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  191. <controls:TextBoxEx Text="{Binding TreeSelectedAccount.DisplayLastName,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,ValidatesOnDataErrors=True}" Validation.ErrorTemplate="{StaticResource ValidationTemplate}" HorizontalContentAlignment="Stretch" TextSaved="{Binding Mode=TwoWay, Path=TreeSelectedAccount.LastNameTextSaved }" x:Name="TbLastName"
  192. HorizontalAlignment="Left" VerticalAlignment="Top" MaxLength="50" Width="200">
  193. <i:Interaction.Triggers>
  194. <i:EventTrigger EventName="TextChanged">
  195. <micro:ActionMessage MethodName="OnAccountChanged">
  196. </micro:ActionMessage>
  197. </i:EventTrigger>
  198. </i:Interaction.Triggers>
  199. </controls:TextBoxEx>
  200. </Border>
  201. </Grid>
  202. <Grid x:Name="GdEmail" Grid.Row="5">
  203. <Grid.ColumnDefinitions>
  204. <ColumnDefinition Width="120"/>
  205. <ColumnDefinition/>
  206. </Grid.ColumnDefinitions>
  207. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  208. <TextBlock Text="Email" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="12" FontFamily="Arial" VerticalAlignment="Center"/>
  209. </Border>
  210. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  211. <controls:TextBoxEx Text="{Binding TreeSelectedAccount.DisplayEmail,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,ValidatesOnDataErrors=True}" Validation.ErrorTemplate="{StaticResource ValidationTemplate}" HorizontalContentAlignment="Stretch" TextSaved="{Binding Mode=TwoWay, Path=TreeSelectedAccount.EmailTextSaved }" x:Name="TbEmail"
  212. HorizontalAlignment="Left" VerticalAlignment="Top" MaxLength="50" Width="200">
  213. <i:Interaction.Triggers>
  214. <i:EventTrigger EventName="TextChanged">
  215. <micro:ActionMessage MethodName="OnAccountChanged">
  216. </micro:ActionMessage>
  217. </i:EventTrigger>
  218. </i:Interaction.Triggers>
  219. </controls:TextBoxEx>
  220. </Border>
  221. </Grid>-->
  222. <Grid x:Name="GdDescription" Grid.Row="3">
  223. <Grid.ColumnDefinitions>
  224. <ColumnDefinition Width="150"/>
  225. <ColumnDefinition/>
  226. </Grid.ColumnDefinitions>
  227. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1,0,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  228. <TextBlock Text="Description" TextWrapping="Wrap" Foreground="{DynamicResource FG_Black}" FontSize="16" VerticalAlignment="Center"/>
  229. </Border>
  230. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,0,1,1" Background="{DynamicResource Table_BG_Content}" Grid.Column="1" Padding="5,1">
  231. <TextBox Text="{Binding TreeSelectedAccount.DisplayDescription,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged,ValidatesOnDataErrors=True}" Validation.ErrorTemplate="{StaticResource ValidationTemplate}" HorizontalContentAlignment="Stretch" x:Name="TbDescription"
  232. HorizontalAlignment="Left" VerticalAlignment="Stretch" MaxLength="50" MinWidth="200">
  233. <i:Interaction.Triggers>
  234. <i:EventTrigger EventName="TextChanged">
  235. <micro:ActionMessage MethodName="OnAccountChanged">
  236. </micro:ActionMessage>
  237. </i:EventTrigger>
  238. </i:Interaction.Triggers>
  239. </TextBox>
  240. </Border>
  241. </Grid>
  242. </Grid>
  243. <TabControl Grid.Row="2" Margin="0,10,10,0">
  244. <TabItem>
  245. <TabItem.Header>
  246. <TextBlock Text="Role Status" FontWeight="Bold"/>
  247. </TabItem.Header>
  248. <ListView Name="RolesStatusList" AlternationCount="2" ItemsSource="{Binding Path=TreeSelectedAccount.RoleColleciton}" VerticalAlignment="Top">
  249. <ListView.View>
  250. <GridView>
  251. <GridViewColumn Width="250" Header="Role" DisplayMemberBinding="{Binding RoleName}"/>
  252. <GridViewColumn Width="300" Header="Status">
  253. <GridViewColumn.CellTemplate>
  254. <DataTemplate >
  255. <CheckBox IsChecked="{Binding DisplayRoleStatus}" Height="30" VerticalContentAlignment="Center">
  256. <i:Interaction.Triggers>
  257. <i:EventTrigger EventName="Click">
  258. <micro:ActionMessage MethodName="OnAccountChanged">
  259. </micro:ActionMessage>
  260. </i:EventTrigger>
  261. </i:Interaction.Triggers>
  262. </CheckBox>
  263. </DataTemplate>
  264. </GridViewColumn.CellTemplate>
  265. </GridViewColumn>
  266. </GridView>
  267. </ListView.View>
  268. </ListView>
  269. </TabItem>
  270. </TabControl>
  271. </Grid>
  272. <StackPanel Grid.Row="1" Grid.ColumnSpan="2" Orientation="Horizontal" VerticalAlignment="Center" HorizontalAlignment="Left" Margin="300,0,0,0">
  273. <Button Content="Create" Style="{StaticResource ViewEnabledBtn}" Command="{Binding BtnAddAccountCommand}" Height="38" Width="100" />
  274. <Button Content="Delete" Style="{StaticResource ViewEnabledBtn}" Command="{Binding BtnDeleteAccountCommand}" Height="38" Width="100" Margin="10,0,0,0"/>
  275. <Button Content="Clone" Style="{StaticResource ViewEnabledBtn}" Command="{Binding BtnCloneAccountCommand}" Height="38" Width="100" Margin="10,0,0,0"/>
  276. <Button Content="Save" Style="{StaticResource EditEnabledBtn}" Command="{Binding BtnSaveAccountCommand}" Height="38" Width="100" Margin="10,0,0,0"/>
  277. <Button Content="Cancel" Style="{StaticResource EditEnabledBtn}" Command="{Binding BtnCancelAccountCommand}" Height="38" Width="100" Margin="10,0,0,0"/>
  278. </StackPanel>
  279. </Grid>
  280. </Grid>
  281. </UserControl>