Files
hive/frontend/node_modules/@testing-library/user-event/dist/cjs/event/focus.js
anthonyrawlins aacb45156b Set up comprehensive frontend testing infrastructure
- Install Jest for unit testing with React Testing Library
- Install Playwright for end-to-end testing
- Configure Jest with proper TypeScript support and module mapping
- Create test setup files and utilities for both unit and e2e tests

Components:
* Jest configuration with coverage thresholds
* Playwright configuration with browser automation
* Unit tests for LoginForm, AuthContext, and useSocketIO hook
* E2E tests for authentication, dashboard, and agents workflows
* GitHub Actions workflow for automated testing
* Mock data and API utilities for consistent testing
* Test documentation with best practices

Testing features:
- Unit tests with 70% coverage threshold
- E2E tests with API mocking and user journey testing
- CI/CD integration for automated test runs
- Cross-browser testing support with Playwright
- Authentication system testing end-to-end

🚀 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-11 14:06:34 +10:00

35 lines
1.5 KiB
JavaScript

'use strict';
require('../utils/dataTransfer/Clipboard.js');
var getActiveElement = require('../utils/focus/getActiveElement.js');
var isFocusable = require('../utils/focus/isFocusable.js');
var findClosest = require('../utils/misc/findClosest.js');
var updateSelectionOnFocus = require('./selection/updateSelectionOnFocus.js');
var wrapEvent = require('./wrapEvent.js');
// Browsers do not dispatch FocusEvent if the document does not have focus.
// TODO: simulate FocusEvent in browsers
/**
* Focus closest focusable element.
*/ function focusElement(element) {
const target = findClosest.findClosest(element, isFocusable.isFocusable);
const activeElement = getActiveElement.getActiveElement(element.ownerDocument);
if ((target !== null && target !== undefined ? target : element.ownerDocument.body) === activeElement) {
return;
} else if (target) {
wrapEvent.wrapEvent(()=>target.focus());
} else {
wrapEvent.wrapEvent(()=>activeElement === null || activeElement === undefined ? undefined : activeElement.blur());
}
updateSelectionOnFocus.updateSelectionOnFocus(target !== null && target !== undefined ? target : element.ownerDocument.body);
}
function blurElement(element) {
if (!isFocusable.isFocusable(element)) return;
const wasActive = getActiveElement.getActiveElement(element.ownerDocument) === element;
if (!wasActive) return;
wrapEvent.wrapEvent(()=>element.blur());
}
exports.blurElement = blurElement;
exports.focusElement = focusElement;