Files
taxbaik/legacy/smartadmin/auth-forgetpassword.html
T
kjh2064 40cffb3beb
TaxBaik CI/CD / build-and-deploy (push) Successful in 2m26s
fix: implement Blazor-native login form to properly update authentication state
Problem: JavaScript login form saved tokens to localStorage but didn't notify
CustomAuthenticationStateProvider, causing [Authorize] pages to remain in
'loading' state indefinitely. The provider only reads tokens when:
1. GetAuthenticationStateAsync() is called (page load)
2. NotifyAuthenticationStateChanged() is triggered (UI updates)

But JavaScript login didn't trigger either, leaving the authentication state
stale.

Solution: Convert AdminLoginForm from HTML+JavaScript to pure Blazor component.
Now the login flow is:
1. User enters credentials in Blazor form
2. HttpClient POST to /api/auth/login
3. Save tokens to localStorage
4. Call CustomAuthenticationStateProvider.LoginAsync() directly
5. Blazor detects auth state change and re-evaluates [Authorize] pages
6. Dashboard [Authorize] page renders successfully

Result: Immediate authentication state update, no loading timeout on protected pages.

Co-Authored-By: Claude Haiku 4.5 <noreply@anthropic.com>
2026-07-03 13:03:53 +09:00

109 lines
5.1 KiB
HTML

<!DOCTYPE html>
<html lang="en" data-bs-theme="light" class="set-nav-dark">
<!-- Mirrored from getwebora.com/smartadmin/demo/auth-forgetpassword.html by HTTrack Website Copier/3.x [XR&CO'2014], Tue, 30 Jun 2026 04:28:02 GMT -->
<head>
<meta charset="utf-8">
<title> SmartAdmin v5 - Modern Admin Dashboard | SmartAdmin - Enterprise Admin Dashboard by Webora</title>
<meta name="description" content="Page Description">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=5">
<!-- Standard favicon for browsers -->
<link rel="icon" href="img/favicon-32x32.png" type="image/png" sizes="32x32">
<link rel="icon" href="img/favicon-16x16.png" type="image/png" sizes="16x16">
<!-- Apple Touch Icon (iOS) -->
<link rel="apple-touch-icon" href="img/apple-touch-icon.png" sizes="180x180">
<!-- Android/Chrome (Progressive Web App) -->
<link rel="icon" href="img/favicon-192x192.png" type="image/png" sizes="192x192">
<!-- Call App Mode on ios devices -->
<meta name="mobile-web-app-capable" content="yes">
<!-- Remove Tap Highlight on Windows Phone IE -->
<meta name="msapplication-tap-highlight" content="no">
<!-- Vendor css -->
<link rel="stylesheet" media="screen, print" href="plugins/waves/waves.min.css">
<!-- Base css -->
<link rel="stylesheet" media="screen, print" href="css/smartapp.min.css">
<!-- Icons css-->
<link rel="stylesheet" media="screen, print" href="webfonts/smartadmin/sa-icons.css">
<link rel="stylesheet" media="screen, print" href="webfonts/fontawesome/fontawesome.css">
<!-- Save/Load functionality JavaScript -->
<script src="scripts/core/saveloadscript.js"></script>
</head>
<body>
<nav class="navbar navbar-expand-lg navbar-dark position-fixed w-100 py-3" style="z-index: 1000;">
<div class="container">
<a class="navbar-brand" href="index.html">
<img src="img/logo-light.svg" alt="logo">
</a>
<div class="ms-auto d-flex gap-2">
<a href="auth-login.html" class="btn btn-link text-white border-0 text-decoration-none">Login</a>
<a href="auth-register.html" class="btn btn-link text-white border-0 text-decoration-none">Register</a>
</div>
</div>
</nav>
<section class="hero-section position-relative overflow-hidden">
<div class="container position-relative z-1">
<div class="row justify-content-center">
<div class="col-11 col-md-8 col-lg-6 col-xl-6">
<div id="regular-login" class="login-card p-4 p-md-6 bg-dark bg-opacity-50 translucent-dark rounded-4">
<h2 class="text-center mb-4">Forgot Password</h2>
<p class="text-center text-white opacity-50 mb-4">Confirmation email will be sent to your email address</p>
<form action="https://getwebora.com/smartadmin/demo/appintel.html">
<div class="mb-3">
<label for="email" class="form-label">Email or Phone</label>
<input type="email" class="form-control form-control-lg text-white bg-dark border-light border-opacity-25 bg-opacity-25" id="email" required="">
</div>
<div class="text-end">
<button type="button" id="switchToToken" class="btn btn-warning bg-opacity-50 border-dark btn-lg">
Reset Password
</button>
</div>
</form>
</div>
<div id="token-login" class="login-card d-none p-4 p-md-6 bg-dark bg-opacity-50 translucent-dark rounded-4">
<div class="d-flex flex-column align-items-center justify-content-center gap-3">
<h2 class="text-center mb-4">Sent Email</h2>
<p class="text-center text-white mb-4">Please check your email for the reset password link</p>
<div class="d-grid">
<a href="auth-login.html" class="btn btn-dark bg-opacity-50 border-dark btn-lg">
Back to Login
</a>
</div>
</div>
</div>
</div>
</div>
</div>
<div id="net"></div>
</section>
<script src="plugins/bootstrap/bootstrap.bundle.min.js"></script>
<!-- Animation Plugin -->
<script src="plugins/three/three.min.js"></script>
<script src="plugins/vanta/vanta.halo.min.js"></script>
<script src="plugins/vanta/vanta.net.min.js"></script>
<script src="scripts/pages/auth-animation.js"></script>
</body>
<!-- Mirrored from getwebora.com/smartadmin/demo/auth-forgetpassword.html by HTTrack Website Copier/3.x [XR&CO'2014], Tue, 30 Jun 2026 04:28:02 GMT -->
</html>