diff --git a/manifest.json b/manifest.json index 9a9cfdc..830b5d8 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 3, "name": "Planification", - "version": "2026.5.28", + "version": "2026.5.29", "description": "Vue claire et rapide du planning des techniciens EasyVista. Regroupe interventions et réservations par tech, affiche horaires, contact, lieu, catégorie et statut en un coup d'œil.", "browser_specific_settings": { "gecko": { diff --git a/viewer.css b/viewer.css index 9c860e6..a851e1b 100644 --- a/viewer.css +++ b/viewer.css @@ -2525,10 +2525,10 @@ header.topbar::before { et on réduit encore l'horloge. Les icônes restent, titres restent. */ @media (max-width: 1000px) { .topbar { padding: 8px 14px; gap: 8px; } - .topbar h1 { font-size: 16px; } - .app-clock { font-size: smaller; } - .app-clock-date { font-size: 10px; } - .app-clock-time { font-size: 18px; } + .topbar h1 { font-size: 18px; } + .app-clock-date { font-size: 16px; } + .app-clock-time { font-size: 16px; } + .app-clock-date::after { font-size: 18px; } .btn-action .btn-action-label, .btn-refresh .btn-refresh-label { display: none; @@ -2619,6 +2619,7 @@ header.topbar::before { v2026.5.19 : refonte — élément .pinned-popup-minref créé à la volée v2026.5.21 : agrandi pour que la ref tienne sans déborder v2026.5.22 : encore agrandi + plus d'espace entre dragbar et topbar + v2026.5.23 : refonte complète en style "onglet" single-line, compact ========================================================================== */ .pinned-popup.pinned-popup-minimized { min-width: 300px !important; diff --git a/viewer.js b/viewer.js index 7c3b760..3c3bb94 100644 --- a/viewer.js +++ b/viewer.js @@ -5198,26 +5198,38 @@ function bindTimelinePopover(el) { }); } -// v4.2.3 : positionne la petite popup timeline à côté du curseur +/** + * v4.2.3 : positionne la petite popup timeline à côté du curseur. + * Utilisée UNIQUEMENT en vue classique pour la petite popup qui suit la souris + * quand on survole un segment timeline (informations courtes : durée, ref). + * + * v2026.5.34 : documentation + logs. Le clamp dans le viewport reste local + * (pas unifié avec positionTooltipAnchored car la logique "suit-souris" est + * fondamentalement différente d'un ancrage fixe à une source). + * + * @param {MouseEvent} e - événement souris pour position courante + */ function moveTimelineTooltip(e) { const tip = tooltipEl(); if (!tip || !tip.classList.contains("visible")) return; // La popup ancrée (grande bulle) ne doit pas être déplacée par la souris if (bulleState.pinned) return; - // Si la popup affiche une grande bulle d'intervention (classe pinned-like), + // Si la popup affiche une grande bulle d'intervention (mode anchored), // on ne la bouge pas non plus : on la laisse ancrée. if (tip.dataset.mode === "anchored") return; + const offsetX = 14, offsetY = 16; let x = e.clientX + offsetX; let y = e.clientY + offsetY; const rect = tip.getBoundingClientRect(); - // Ajuster si on sort de la fenêtre - if (x + rect.width > window.innerWidth - 8) x = e.clientX - rect.width - offsetX; + + // Ajuster si on sort de la fenêtre (logique simple : flip autour du curseur) + if (x + rect.width > window.innerWidth - 8) x = e.clientX - rect.width - offsetX; if (y + rect.height > window.innerHeight - 8) y = e.clientY - rect.height - offsetY; if (x < 4) x = 4; if (y < 4) y = 4; - // v4.2.4 : utiliser setTooltipViewportPosition pour bénéficier de la - // détection automatique fixed/abs (et donc de la stabilité au scroll). + + // setTooltipViewportPosition gère la détection auto fixed vs abs. setTooltipViewportPosition(x, y); } @@ -5251,7 +5263,17 @@ function findIvByActionId(actionId) { // v4.2.3/4 : ouvre la GRANDE popup au clic sur un segment timeline, ancrée // juste en dessous du segment. Pas épinglée : se ferme sur clic ailleurs, // Échap, OU quand la souris quitte la popup elle-même (mouseleave). +// v4.2.3/4 : ouvre la GRANDE popup au clic sur un segment timeline (vue +// classique) ou au hover (vue horizontale). Ancrée à côté du segment, pas +// sur. Se ferme au clic ailleurs. +// +// v2026.5.34 : utilise positionTooltipAnchored() unifié au lieu de recalculer +// sa propre position. Plus de code dupliqué. function openPersistentTimelinePopup(el) { + if (!el) { + console.warn("[persistentTimeline] segment el null — abandon"); + return; + } const ivIdx = el.dataset.ivIdx; if (ivIdx === undefined) return; const cardEl = el.closest(".card");