Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
102 lines
2.6 KiB
JavaScript
102 lines
2.6 KiB
JavaScript
import { useDetectKeyboardLayout } from 'dashboard/composables/useDetectKeyboardLayout';
|
|
import {
|
|
LAYOUT_QWERTY,
|
|
LAYOUT_QWERTZ,
|
|
LAYOUT_AZERTY,
|
|
} from 'shared/helpers/KeyboardHelpers';
|
|
|
|
describe('useDetectKeyboardLayout', () => {
|
|
beforeEach(() => {
|
|
window.cw_keyboard_layout = null;
|
|
});
|
|
|
|
it('returns cached layout if available', async () => {
|
|
window.cw_keyboard_layout = LAYOUT_QWERTY;
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect(layout).toBe(LAYOUT_QWERTY);
|
|
});
|
|
|
|
it('should detect QWERTY layout using modern method', async () => {
|
|
navigator.keyboard = {
|
|
getLayoutMap: vi.fn().mockResolvedValue(
|
|
new Map([
|
|
['KeyQ', 'q'],
|
|
['KeyW', 'w'],
|
|
['KeyE', 'e'],
|
|
['KeyR', 'r'],
|
|
['KeyT', 't'],
|
|
['KeyY', 'y'],
|
|
])
|
|
),
|
|
};
|
|
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect(layout).toBe(LAYOUT_QWERTY);
|
|
});
|
|
|
|
it('should detect QWERTZ layout using modern method', async () => {
|
|
navigator.keyboard = {
|
|
getLayoutMap: vi.fn().mockResolvedValue(
|
|
new Map([
|
|
['KeyQ', 'q'],
|
|
['KeyW', 'w'],
|
|
['KeyE', 'e'],
|
|
['KeyR', 'r'],
|
|
['KeyT', 't'],
|
|
['KeyY', 'z'],
|
|
])
|
|
),
|
|
};
|
|
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect(layout).toBe(LAYOUT_QWERTZ);
|
|
});
|
|
|
|
it('should detect AZERTY layout using modern method', async () => {
|
|
navigator.keyboard = {
|
|
getLayoutMap: vi.fn().mockResolvedValue(
|
|
new Map([
|
|
['KeyQ', 'a'],
|
|
['KeyW', 'z'],
|
|
['KeyE', 'e'],
|
|
['KeyR', 'r'],
|
|
['KeyT', 't'],
|
|
['KeyY', 'y'],
|
|
])
|
|
),
|
|
};
|
|
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect(layout).toBe(LAYOUT_AZERTY);
|
|
});
|
|
|
|
it('should use legacy method if navigator.keyboard is not available', async () => {
|
|
navigator.keyboard = undefined;
|
|
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect([LAYOUT_QWERTY, LAYOUT_QWERTZ, LAYOUT_AZERTY]).toContain(layout);
|
|
});
|
|
|
|
it('should cache the detected layout', async () => {
|
|
navigator.keyboard = {
|
|
getLayoutMap: vi.fn().mockResolvedValue(
|
|
new Map([
|
|
['KeyQ', 'q'],
|
|
['KeyW', 'w'],
|
|
['KeyE', 'e'],
|
|
['KeyR', 'r'],
|
|
['KeyT', 't'],
|
|
['KeyY', 'y'],
|
|
])
|
|
),
|
|
};
|
|
|
|
const layout = await useDetectKeyboardLayout();
|
|
expect(layout).toBe(LAYOUT_QWERTY);
|
|
|
|
const layoutAgain = await useDetectKeyboardLayout();
|
|
expect(layoutAgain).toBe(LAYOUT_QWERTY);
|
|
expect(navigator.keyboard.getLayoutMap).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|