var CONFIG = { endpoint: 'https://example.com/bot-report', thresholdNoMoveOpens: 3, storageKey: 'bt_state_v1', sessionNavKey: 'bt_lastNavByLink' }; function loadState() { try { var raw = localStorage.getItem(CONFIG.storageKey); if (!raw) { return { noMouseMoveCount: 0, shouldReportOnLoad: false }; } var parsed = JSON.parse(raw); if (typeof parsed.noMouseMoveCount !== 'number') { parsed.noMouseMoveCount = 0; } if (typeof parsed.shouldReportOnLoad !== 'boolean') { parsed.shouldReportOnLoad = false; } return parsed; } catch (e) { return { noMouseMoveCount: 0, shouldReportOnLoad: false }; } } function saveState(state) { try { localStorage.setItem(CONFIG.storageKey, JSON.stringify(state)); } catch (e) { } } function detectNavigationContext() { var navType = 'unknown'; var perf = window.performance; if (perf && typeof perf.getEntriesByType === 'function') { var entries = perf.getEntriesByType('navigation'); if (entries && entries[0]) { var type = entries[0].type; if (type === 'reload') navType = 'reload'; else if (type === 'back_forward') navType = 'back_forward'; else if (type === 'navigate') navType = 'navigate'; } } var openedByLink = false; try { if (sessionStorage.getItem(CONFIG.sessionNavKey) === '1') { openedByLink = true; sessionStorage.removeItem(CONFIG.sessionNavKey); } } catch (e) {} var openType; if (navType === 'reload') { openType = 'reload'; } else if (openedByLink) { openType = 'link_click'; } else { openType = 'address_bar_or_other'; } return { navType: navType, openType: openType }; } var navContext = detectNavigationContext(); var mouseMovedThisPage = false; function handleMouseMoveOnce() { mouseMovedThisPage = true; document.removeEventListener('mousemove', handleMouseMoveOnce); } document.addEventListener('mousemove', handleMouseMoveOnce, { passive: true }); function handleClickCapture(event) { var el = event.target; while (el && el !== document) { if (el.tagName && el.tagName.toLowerCase() === 'a' && el.href) { try { sessionStorage.setItem(CONFIG.sessionNavKey, '1'); } catch (e) {} break; } el = el.parentNode; } } document.addEventListener('click', handleClickCapture, true); function sendBotReport(state, context) { var payload = { timestamp: new Date().toISOString(), url: location.href, referrer: document.referrer || null, noMouseMoveCount: state.noMouseMoveCount, openType: context.openType, navType: context.navType, mouseMovedThisPage: mouseMovedThisPage }; console.log('report', payload); } var exitHandled = false; function handleExit() { if (exitHandled) return; exitHandled = true; var state = loadState(); if (mouseMovedThisPage) { state.noMouseMoveCount = 0; } else { state.noMouseMoveCount += 1; } state.shouldReportOnLoad = state.noMouseMoveCount >= CONFIG.thresholdNoMoveOpens; saveState(state); } window.addEventListener('pagehide', handleExit); window.addEventListener('beforeunload', handleExit); document.addEventListener('visibilitychange', function () { if (document.visibilityState === 'hidden') { handleExit(); } }); function handlePageLoaded() { var state = loadState(); if (state.shouldReportOnLoad && state.noMouseMoveCount >= CONFIG.thresholdNoMoveOpens) { sendBotReport(state, navContext); } } if (document.readyState === 'complete' || document.readyState === 'interactive') { handlePageLoaded(); } else { window.addEventListener('DOMContentLoaded', handlePageLoaded); } })(); --}}
british actress