PINLoginPage.xaml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <timesheets:BasePage
  3. xmlns="http://xamarin.com/schemas/2014/forms"
  4. xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
  5. xmlns:material="clr-namespace:XF.Material.Forms.UI;assembly=XF.Material"
  6. xmlns:timesheets="clr-namespace:comal.timesheets"
  7. x:Class="comal.timesheets.PinLoginPage"
  8. BackButtonEnabled="False">
  9. <timesheets:BasePage.ActionButtons>
  10. <ImageButton Clicked="Settings_OnClicked" Source="settings.png"/>
  11. </timesheets:BasePage.ActionButtons>
  12. <timesheets:BasePage.PageContent>
  13. <Grid x:Name="MasterGrid" Background="White">
  14. <Grid.ColumnDefinitions>
  15. <ColumnDefinition Width="*"/>
  16. <ColumnDefinition Width="0"/>
  17. <ColumnDefinition Width="0"/>
  18. <ColumnDefinition Width="0"/>
  19. </Grid.ColumnDefinitions>
  20. <Grid.RowDefinitions>
  21. <RowDefinition Height="*"/>
  22. </Grid.RowDefinitions>
  23. <AbsoluteLayout x:Name="SplashLayout" Grid.Column="0">
  24. <Image Source="logo" AbsoluteLayout.LayoutFlags="All" AbsoluteLayout.LayoutBounds="0.5,0.5,0.75,0.75">
  25. <Image.Margin>
  26. <OnPlatform x:TypeArguments="Thickness">
  27. <On Platform="Android" Value="30"/>
  28. <On Platform="iOS" Value="0"/>
  29. </OnPlatform>
  30. </Image.Margin>
  31. </Image>
  32. </AbsoluteLayout>
  33. <Grid x:Name="PINLayout" Background="White" Grid.Column="1" >
  34. <Grid.ColumnDefinitions>
  35. <ColumnDefinition Width=".3*"/>
  36. <ColumnDefinition Width="*"/>
  37. <ColumnDefinition Width="*"/>
  38. <ColumnDefinition Width="*"/>
  39. <ColumnDefinition Width=".3*"/>
  40. </Grid.ColumnDefinitions>
  41. <Grid.RowDefinitions>
  42. <RowDefinition Height="3*"/>
  43. <RowDefinition Height="2*"/>
  44. <RowDefinition Height="*"/>
  45. <RowDefinition Height="*"/>
  46. <RowDefinition Height="*"/>
  47. <RowDefinition Height="*"/>
  48. <RowDefinition Height="*"/>
  49. <RowDefinition Height=".3*"/>
  50. </Grid.RowDefinitions>
  51. <Image Source="logo" Grid.Row="0" Grid.Column="1" Grid.ColumnSpan="3" >
  52. <Image.Margin>
  53. <OnPlatform x:TypeArguments="Thickness">
  54. <On Platform="Android" Value="30"/>
  55. <On Platform="iOS" Value="0"/>
  56. </OnPlatform>
  57. </Image.Margin>
  58. </Image>
  59. <Label Grid.Row="1" FontAttributes="Bold" FontSize="Medium" LineBreakMode="WordWrap" Text="Enter your PIN Number below: "
  60. VerticalOptions="Center" HorizontalOptions="Center" HorizontalTextAlignment="Center"/>
  61. <Grid Grid.Row="2" Grid.Column="1" Grid.ColumnSpan="3">
  62. <Grid.ColumnDefinitions>
  63. <ColumnDefinition Width="*"/>
  64. <ColumnDefinition Width="*"/>
  65. <ColumnDefinition Width="*"/>
  66. <ColumnDefinition Width="*"/>
  67. </Grid.ColumnDefinitions>
  68. <Grid.RowDefinitions>
  69. <RowDefinition Height="*"/>
  70. </Grid.RowDefinitions>
  71. <Frame Grid.Column="0" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightSkyBlue" Padding="1">
  72. <Entry x:Name="Pin0" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  73. </Frame>
  74. <Frame Grid.Column="1" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightSkyBlue" Padding="1">
  75. <Entry x:Name="Pin1" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  76. </Frame>
  77. <Frame Grid.Column="2" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightSkyBlue" Padding="1">
  78. <Entry x:Name="Pin2" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  79. </Frame>
  80. <Frame Grid.Column="3" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightSkyBlue" Padding="1">
  81. <Entry x:Name="Pin3" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  82. </Frame>
  83. </Grid>
  84. <material:MaterialButton x:Name="PinKey1" Grid.Row="3" Grid.Column="1" Text="1" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  85. <material:MaterialButton x:Name="PinKey2" Grid.Row="3" Grid.Column="2" Text="2" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  86. <material:MaterialButton x:Name="PinKey3" Grid.Row="3" Grid.Column="3" Text="3" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  87. <material:MaterialButton x:Name="PinKey4" Grid.Row="4" Grid.Column="1" Text="4" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  88. <material:MaterialButton x:Name="PinKey5" Grid.Row="4" Grid.Column="2" Text="5" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  89. <material:MaterialButton x:Name="PinKey6" Grid.Row="4" Grid.Column="3" Text="6" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  90. <material:MaterialButton x:Name="PinKey7" Grid.Row="5" Grid.Column="1" Text="7" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  91. <material:MaterialButton x:Name="PinKey8" Grid.Row="5" Grid.Column="2" Text="8" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  92. <material:MaterialButton x:Name="PinKey9" Grid.Row="5" Grid.Column="3" Text="9" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  93. <material:MaterialButton x:Name="PinBack" Grid.Row="6" Grid.Column="1" Text="Clr" Clicked="Pin_Back_Click" IsEnabled="False" IsTabStop="False" ButtonType="Elevated"/>
  94. <material:MaterialButton x:Name="PinKey0" Grid.Row="6" Grid.Column="2" Text="0" Clicked="Pin_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  95. <material:MaterialButton x:Name="PinOK" Grid.Row="6" Grid.Column="3" Text="OK" Clicked="Pin_OK_Click" IsEnabled="False" ButtonType="Elevated" />
  96. </Grid>
  97. <Grid x:Name="TwoFALayout" Background="White" Grid.Column="1" >
  98. <Grid.ColumnDefinitions>
  99. <ColumnDefinition Width=".3*"/>
  100. <ColumnDefinition Width="*"/>
  101. <ColumnDefinition Width="*"/>
  102. <ColumnDefinition Width="*"/>
  103. <ColumnDefinition Width=".3*"/>
  104. </Grid.ColumnDefinitions>
  105. <Grid.RowDefinitions>
  106. <RowDefinition Height="3*"/>
  107. <RowDefinition Height="*"/>
  108. <RowDefinition Height="*"/>
  109. <RowDefinition Height="*"/>
  110. <RowDefinition Height="*"/>
  111. <RowDefinition Height="*"/>
  112. <RowDefinition Height="*"/>
  113. <RowDefinition Height="*"/>
  114. <RowDefinition Height=".3*"/>
  115. </Grid.RowDefinitions>
  116. <Image Source="logo" Grid.Row="0" Grid.Column="1" Grid.ColumnSpan="3">
  117. <Image.Margin>
  118. <OnPlatform x:TypeArguments="Thickness">
  119. <On Platform="Android" Value="30"/>
  120. <On Platform="iOS" Value="0"/>
  121. </OnPlatform>
  122. </Image.Margin>
  123. </Image>
  124. <Label
  125. Grid.Row="1"
  126. Grid.Column="1"
  127. Grid.ColumnSpan="3"
  128. FontAttributes="Bold"
  129. FontSize="Medium"
  130. LineBreakMode="WordWrap"
  131. Text="Enter your 2FA code below, from: "
  132. VerticalOptions="Center"
  133. HorizontalOptions="Center"
  134. HorizontalTextAlignment="Center"/>
  135. <Label
  136. Grid.Row="2"
  137. Grid.Column="1"
  138. Grid.ColumnSpan="3"
  139. FontAttributes="Bold"
  140. FontSize="Medium"
  141. x:Name="TwoFASource"
  142. LineBreakMode="WordWrap"
  143. TextColor="#a2006d"
  144. Margin="3"
  145. VerticalOptions="Center"
  146. HorizontalOptions="Center"
  147. HorizontalTextAlignment="Center"/>
  148. <Grid Grid.Row="3" Grid.Column="1" Grid.ColumnSpan="3">
  149. <Grid.ColumnDefinitions>
  150. <ColumnDefinition Width="*"/>
  151. <ColumnDefinition Width="*"/>
  152. <ColumnDefinition Width="*"/>
  153. <ColumnDefinition Width="*"/>
  154. <ColumnDefinition Width="*"/>
  155. <ColumnDefinition Width="*"/>
  156. <ColumnDefinition Width="*"/>
  157. </Grid.ColumnDefinitions>
  158. <Grid.RowDefinitions>
  159. <RowDefinition Height="*"/>
  160. </Grid.RowDefinitions>
  161. <Frame Grid.Column="0" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  162. <Entry x:Name="TwoFA0" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  163. </Frame>
  164. <Frame Grid.Column="1" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  165. <Entry x:Name="TwoFA1" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  166. </Frame>
  167. <Frame Grid.Column="2" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  168. <Entry x:Name="TwoFA2" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  169. </Frame>
  170. <Frame Grid.Column="3" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  171. <Entry x:Name="TwoFA3" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  172. </Frame>
  173. <Frame Grid.Column="4" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  174. <Entry x:Name="TwoFA4" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  175. </Frame>
  176. <Frame Grid.Column="5" HorizontalOptions="Center" VerticalOptions="Center" WidthRequest="35" BorderColor="LightCoral" Padding="1">
  177. <Entry x:Name="TwoFA5" HorizontalOptions="Center" VerticalOptions="Center" FontSize="Medium" Keyboard="Numeric"/>
  178. </Frame>
  179. </Grid>
  180. <material:MaterialButton x:Name="TwoFAKey1" Grid.Row="4" Grid.Column="1" Text="1" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  181. <material:MaterialButton x:Name="TwoFAKey2" Grid.Row="4" Grid.Column="2" Text="2" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  182. <material:MaterialButton x:Name="TwoFAKey3" Grid.Row="4" Grid.Column="3" Text="3" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  183. <material:MaterialButton x:Name="TwoFAKey4" Grid.Row="5" Grid.Column="1" Text="4" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  184. <material:MaterialButton x:Name="TwoFAKey5" Grid.Row="5" Grid.Column="2" Text="5" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  185. <material:MaterialButton x:Name="TwoFAKey6" Grid.Row="5" Grid.Column="3" Text="6" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  186. <material:MaterialButton x:Name="TwoFAKey7" Grid.Row="6" Grid.Column="1" Text="7" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  187. <material:MaterialButton x:Name="TwoFAKey8" Grid.Row="6" Grid.Column="2" Text="8" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  188. <material:MaterialButton x:Name="TwoFAKey9" Grid.Row="6" Grid.Column="3" Text="9" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  189. <material:MaterialButton x:Name="TwoFABack" Grid.Row="7" Grid.Column="1" Text="Clr" Clicked="TwoFA_Back_Click" IsEnabled="False" IsTabStop="False" ButtonType="Elevated"/>
  190. <material:MaterialButton x:Name="TwoFAKey0" Grid.Row="7" Grid.Column="2" Text="0" Clicked="TwoFA_Button_Click" IsTabStop="False" ButtonType="Elevated" />
  191. <material:MaterialButton x:Name="TwoFAOK" Grid.Row="7" Grid.Column="3" Text="OK" Clicked="TwoFA_OK_Click" IsEnabled="False" ButtonType="Elevated" />
  192. </Grid>
  193. <StackLayout x:Name="PasswordLayout" Background="White" Grid.Column="3" Padding="10">
  194. <material:MaterialLabel Text="New Password (min 5 characters)" TypeScale="H6" HorizontalTextAlignment="Start" Margin="5"/>
  195. <Frame HasShadow="False" Padding="10" BorderColor="Gray" CornerRadius="10">
  196. <Entry x:Name="NewPassword" TextChanged="NewPassword_OnTextChanged"/>
  197. </Frame>
  198. <material:MaterialLabel Text="Confirm Password" TypeScale="H6" HorizontalTextAlignment="Start" Margin="5"/>
  199. <Frame HasShadow="False" Padding="10" BorderColor="Gray" CornerRadius="10">
  200. <Entry x:Name="NewPassword2" TextChanged="NewPassword_OnTextChanged"/>
  201. </Frame>
  202. <Grid>
  203. <Grid.ColumnDefinitions>
  204. <ColumnDefinition Width="*" />
  205. <ColumnDefinition Width="*" x:Name="PasswordCancelColumn"/>
  206. </Grid.ColumnDefinitions>
  207. </Grid>
  208. <material:MaterialButton
  209. Grid.Column="0"
  210. x:Name="ChangePasswordButton"
  211. Text="Change Password"
  212. Padding="10"
  213. IsEnabled="False"
  214. Clicked="ChangePasswordButton_OnClicked"/>
  215. <material:MaterialButton
  216. Grid.Column="1"
  217. x:Name="CancelPasswordButton"
  218. Text="Cancel"
  219. Padding="10"
  220. Clicked="CancelPasswordButton_OnClicked"/>
  221. </StackLayout>
  222. </Grid>
  223. </timesheets:BasePage.PageContent>
  224. </timesheets:BasePage>