Visual rewrite of the NFC kiosk page: - Animated mesh gradient background (drifts on a 28s loop) - Glass-panel state cards with backdrop-filter blur - Animated SVG NFC icon (concentric waves emanate from a chip) - Company logo pulled from res.company.logo, displayed in header - Dominant-hue extraction from logo sets --nfc-h CSS var; entire palette interpolates from that one HSL hue - Success burst (green glow + scale), error shake, smooth state fades - Reduced-motion fallback respects prefers-reduced-motion - Glass numpad + employee picker in Enroll Mode CRITICAL FIX: scoped all kiosk styles under :has(#nfc_kiosk_root) so they no longer leak into other frontend pages. Previous version applied html/body overflow:hidden + display:none on header/footer globally, breaking website scrolling and chrome on every frontend page.
55 lines
2.7 KiB
XML
55 lines
2.7 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<odoo>
|
|
|
|
<template id="nfc_kiosk_page" name="NFC Clock Kiosk">
|
|
<t t-call="web.frontend_layout">
|
|
<t t-set="no_header" t-value="True"/>
|
|
<t t-set="no_footer" t-value="True"/>
|
|
<t t-set="head">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"/>
|
|
</t>
|
|
|
|
<div id="nfc_kiosk_root" class="nfc-kiosk"
|
|
t-att-data-photo-required="'1' if photo_required else '0'"
|
|
t-att-data-debug-enabled="'1' if debug_enabled else '0'"
|
|
t-att-data-location-configured="'1' if location_configured else '0'"
|
|
t-att-data-company-logo-url="company_logo_url or ''">
|
|
|
|
<!-- Company logo (also drives the dominant-hue palette via JS) -->
|
|
<img t-if="company_logo_url"
|
|
class="nfc-kiosk__logo"
|
|
id="nfc_company_logo"
|
|
t-att-src="company_logo_url"
|
|
crossorigin="anonymous"
|
|
alt="Company logo"/>
|
|
|
|
<!-- Static chrome (always visible) -->
|
|
<div class="nfc-kiosk__company" t-esc="company_name"/>
|
|
<div class="nfc-kiosk__time" id="nfc_clock_time">--:--</div>
|
|
<div class="nfc-kiosk__date" id="nfc_clock_date">—</div>
|
|
<div class="nfc-kiosk__location">
|
|
<span t-if="location_configured">Clock at: <t t-esc="location_name"/></span>
|
|
<span t-else="" style="color:#d9374e">⚠ No location configured</span>
|
|
</div>
|
|
<button class="nfc-kiosk__settings" id="nfc_settings_btn" title="Enroll Mode">⚙</button>
|
|
|
|
<!-- Dynamic state container (JS swaps inner HTML based on state) -->
|
|
<div id="nfc_state_container">
|
|
<!-- Initial: One-time setup wizard -->
|
|
<div class="nfc-kiosk__setup">
|
|
<h2>Welcome to Fusion Clock NFC Kiosk</h2>
|
|
<p>Tap the button below to enable the NFC reader and camera. This is a one-time setup for this device.</p>
|
|
<button id="nfc_setup_start">Tap to enable NFC reader</button>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Hidden video + canvas for camera capture -->
|
|
<video id="nfc_camera_feed" autoplay="autoplay" playsinline="playsinline" muted="muted"
|
|
style="position:absolute; width:1px; height:1px; opacity:0; pointer-events:none;"/>
|
|
<canvas id="nfc_camera_canvas" style="display:none;"/>
|
|
</div>
|
|
</t>
|
|
</template>
|
|
|
|
</odoo>
|