2023-08-21 17:01:20 +02:00
|
|
|
import * as React from 'react';
|
|
|
|
import { Size } from '@joplin/utils/types';
|
|
|
|
import { useEffect, useState } from 'react';
|
2023-09-18 18:40:36 +02:00
|
|
|
import { ItemFlow } from '@joplin/lib/services/plugins/api/noteListType';
|
2023-08-21 17:01:20 +02:00
|
|
|
|
2024-08-31 17:05:01 +02:00
|
|
|
const useItemElement = (
|
|
|
|
rootElement: HTMLDivElement, noteId: string, noteHtml: string, focusVisible: boolean, style: React.CSSProperties, itemSize: Size, onClick: React.MouseEventHandler<HTMLDivElement>, flow: ItemFlow,
|
|
|
|
) => {
|
2023-08-21 17:01:20 +02:00
|
|
|
const [itemElement, setItemElement] = useState<HTMLDivElement>(null);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (!rootElement) return () => {};
|
|
|
|
|
|
|
|
const element = document.createElement('div');
|
|
|
|
element.setAttribute('data-id', noteId);
|
|
|
|
element.className = 'note-list-item';
|
|
|
|
for (const [n, v] of Object.entries(style)) {
|
2024-04-05 13:16:49 +02:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-08-21 17:01:20 +02:00
|
|
|
(element.style as any)[n] = v;
|
|
|
|
}
|
|
|
|
if (flow === ItemFlow.LeftToRight) element.style.width = `${itemSize.width}px`;
|
|
|
|
element.style.height = `${itemSize.height}px`;
|
|
|
|
element.innerHTML = noteHtml;
|
2024-04-05 13:16:49 +02:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-08-21 17:01:20 +02:00
|
|
|
element.addEventListener('click', onClick as any);
|
|
|
|
|
|
|
|
rootElement.appendChild(element);
|
|
|
|
|
|
|
|
setItemElement(element);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
element.remove();
|
|
|
|
};
|
|
|
|
}, [rootElement, itemSize, noteHtml, noteId, style, onClick, flow]);
|
|
|
|
|
2024-08-31 17:05:01 +02:00
|
|
|
useEffect(() => {
|
|
|
|
if (!itemElement) return;
|
|
|
|
|
|
|
|
if (focusVisible) {
|
|
|
|
itemElement.classList.add('-focus-visible');
|
|
|
|
} else {
|
|
|
|
itemElement.classList.remove('-focus-visible');
|
|
|
|
}
|
|
|
|
}, [focusVisible, itemElement]);
|
|
|
|
|
2023-08-21 17:01:20 +02:00
|
|
|
return itemElement;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default useItemElement;
|