No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

login.component.html 2.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <div class="login-container">
  2. <mat-card class="login-card">
  3. <mat-card-header class="card-header">
  4. <div class="logo-container">
  5. <div class="logo-icon">
  6. <mat-icon class="icon">settings</mat-icon>
  7. </div>
  8. <mat-card-title class="title">ERP-AGI对话系统</mat-card-title>
  9. </div>
  10. </mat-card-header>
  11. <mat-card-content class="card-content">
  12. <form [formGroup]="loginForm" (ngSubmit)="onSubmit()" class="login-form">
  13. <mat-form-field appearance="outline" class="full-width">
  14. <mat-icon matPrefix>person</mat-icon>
  15. <mat-label>用户名</mat-label>
  16. <input matInput formControlName="username" autocomplete="username" autofocus #usernameInput>
  17. </mat-form-field>
  18. <mat-form-field appearance="outline" class="full-width">
  19. <mat-label>密码</mat-label>
  20. <input matInput [type]="hidePassword ? 'password' : 'text'" formControlName="password" placeholder="请输入密码" autocomplete="current-password">
  21. <mat-icon matPrefix>lock</mat-icon>
  22. <button type="button" mat-icon-button matSuffix (click)="hidePassword = !hidePassword" [attr.aria-label]="'隐藏密码'" [attr.aria-pressed]="hidePassword">
  23. <mat-icon>{{hidePassword ? 'visibility_off' : 'visibility'}}</mat-icon>
  24. </button>
  25. </mat-form-field>
  26. @if (errorMessage) {
  27. <div class="error-message">
  28. <mat-icon>error</mat-icon>
  29. <span>{{ errorMessage }}</span>
  30. </div>
  31. }
  32. <button mat-raised-button color="primary" type="submit" class="login-button" [disabled]="isLoading || loginForm.invalid">
  33. @if (isLoading) {
  34. <mat-spinner diameter="24" class="spinner"></mat-spinner>
  35. } @else {
  36. <span class="button-content">
  37. <mat-icon>login</mat-icon>
  38. <span>登录</span>
  39. </span>
  40. }
  41. </button>
  42. </form>
  43. </mat-card-content>
  44. <mat-card-footer class="card-footer">
  45. <div class="footer-content">
  46. <p>广东志华软件科技有限公司</p>
  47. <p>Copyright &copy; 2026</p>
  48. </div>
  49. </mat-card-footer>
  50. </mat-card>
  51. </div>