- Intégration LineIcons Duotone (css/ + toutes les pages) - Remplacement de tous les symboles Unicode par des icônes lnid-* - Page profile.html : préférences thème, position sidebar, langue - Dashboard : système de widgets add/remove + drag-and-drop natif - Sidebar gauche/droite configurable per-user (data-sidebar CSS + FOUC script) - Store ui : sidebarPosition, applySidebarPosition(), setSidebarPosition() - Composant profilePage() dans app.js - nav.profile ajouté dans fr.json et en.json - SUIVI.md mis à jour Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
63 lines
2.1 KiB
HTML
63 lines
2.1 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="fr">
|
|
<head>
|
|
<script>(function(){document.documentElement.setAttribute("data-theme",localStorage.getItem("pxp_theme")||"dark")})()</script>
|
|
<meta charset="UTF-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
<title>ProxmoxPanel — Connexion</title>
|
|
<link rel="stylesheet" href="/css/neu.css" />
|
|
<link rel="stylesheet" href="/css/dark.css" />
|
|
<link rel="stylesheet" href="/css/light.css" />
|
|
<link rel="stylesheet" href="/css/pages.css" />
|
|
<link rel="stylesheet" href="/css/lineicons-duotone.css" />
|
|
<script src="/js/vendors/htmx.min.js"></script>
|
|
<script src="/js/vendors/swup.iife.js"></script>
|
|
<script src="/js/app.js"></script>
|
|
<script src="/js/vendors/alpine.min.js" defer></script>
|
|
</head>
|
|
<body x-data>
|
|
<div class="auth-layout" x-data="loginPage()" x-cloak>
|
|
<div class="auth-card neu-card">
|
|
<div class="auth-logo">
|
|
<i class="logo-icon lnid-layout-1"></i>
|
|
<h1 class="auth-title">ProxmoxPanel</h1>
|
|
<p class="auth-subtitle" x-text="t('login.subtitle')"></p>
|
|
</div>
|
|
|
|
<form @submit.prevent="submit" class="auth-form">
|
|
<div class="form-group">
|
|
<label class="form-label" x-text="t('login.username')"></label>
|
|
<input
|
|
class="neu-input"
|
|
type="text"
|
|
x-model="username"
|
|
:placeholder="t('login.usernamePlaceholder')"
|
|
autocomplete="username"
|
|
required
|
|
/>
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
<label class="form-label" x-text="t('login.password')"></label>
|
|
<input
|
|
class="neu-input"
|
|
type="password"
|
|
x-model="password"
|
|
:placeholder="t('login.passwordPlaceholder')"
|
|
autocomplete="current-password"
|
|
required
|
|
/>
|
|
</div>
|
|
|
|
<div class="form-error" x-show="error" x-text="error" role="alert"></div>
|
|
|
|
<button class="neu-btn neu-btn--primary auth-submit" type="submit" :disabled="loading">
|
|
<span x-show="!loading" x-text="t('login.submit')"></span>
|
|
<span x-show="loading" class="spinner"></span>
|
|
</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
</body>
|
|
</html>
|