2024-04-01 15:34:22 +01:00
|
|
|
// The purpose of this handler is to have all focus/blur calls go through the same place, which
|
|
|
|
// makes it easier to log what happens. This is useful when one unknown component is stealing focus
|
|
|
|
// from another component. Potentially it could also be used to resolve conflict situations when
|
|
|
|
// multiple components try to set the focus at the same time.
|
|
|
|
|
|
|
|
import Logger from '@joplin/utils/Logger';
|
|
|
|
|
2024-04-01 16:47:50 +01:00
|
|
|
const logger = Logger.create('focusHandler');
|
2024-04-01 15:34:22 +01:00
|
|
|
|
|
|
|
enum ToggleFocusAction {
|
|
|
|
Focus = 'focus',
|
|
|
|
Blur = 'blur',
|
|
|
|
}
|
|
|
|
|
2024-10-15 09:59:51 -07:00
|
|
|
interface FocusOptions {
|
|
|
|
preventScroll: boolean;
|
|
|
|
}
|
|
|
|
|
2024-04-01 15:34:22 +01:00
|
|
|
interface FocusableElement {
|
2024-10-15 09:59:51 -07:00
|
|
|
focus: (options?: FocusOptions)=> void;
|
2024-04-01 15:34:22 +01:00
|
|
|
blur: ()=> void;
|
|
|
|
}
|
|
|
|
|
2024-10-15 09:59:51 -07:00
|
|
|
const toggleFocus = (source: string, element: FocusableElement, action: ToggleFocusAction, options: FocusOptions|null) => {
|
2024-04-01 15:34:22 +01:00
|
|
|
if (!element) {
|
|
|
|
logger.warn(`Tried action "${action}" on an undefined element: ${source}`);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!element[action]) {
|
|
|
|
logger.warn(`Element does not have a "${action}" method: ${source}`);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.debug(`Action "${action}" from "${source}"`);
|
2024-10-15 09:59:51 -07:00
|
|
|
if (options) {
|
|
|
|
element[action](options);
|
|
|
|
} else {
|
|
|
|
element[action]();
|
|
|
|
}
|
2024-04-01 15:34:22 +01:00
|
|
|
};
|
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2024-10-15 09:59:51 -07:00
|
|
|
export const focus = (source: string, element: any, options: FocusOptions|null = null) => {
|
|
|
|
toggleFocus(source, element, ToggleFocusAction.Focus, options);
|
2024-04-01 15:34:22 +01:00
|
|
|
};
|
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2024-04-01 15:34:22 +01:00
|
|
|
export const blur = (source: string, element: any) => {
|
2024-10-15 09:59:51 -07:00
|
|
|
toggleFocus(source, element, ToggleFocusAction.Blur, null);
|
2024-04-01 15:34:22 +01:00
|
|
|
};
|