2023-08-21 16:01:20 +01:00
|
|
|
import * as React from 'react';
|
|
|
|
import { Size } from '@joplin/utils/types';
|
|
|
|
import { useEffect, useState } from 'react';
|
2023-09-18 17:40:36 +01:00
|
|
|
import { ItemFlow } from '@joplin/lib/services/plugins/api/noteListType';
|
2023-08-21 16:01:20 +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
|
2023-08-21 16:01:20 +01:00
|
|
|
const useItemElement = (rootElement: HTMLDivElement, noteId: string, noteHtml: string, style: any, itemSize: Size, onClick: React.MouseEventHandler<HTMLDivElement>, flow: ItemFlow) => {
|
|
|
|
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 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-08-21 16:01:20 +01: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 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-08-21 16:01:20 +01:00
|
|
|
element.addEventListener('click', onClick as any);
|
|
|
|
|
|
|
|
rootElement.appendChild(element);
|
|
|
|
|
|
|
|
setItemElement(element);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
element.remove();
|
|
|
|
};
|
|
|
|
}, [rootElement, itemSize, noteHtml, noteId, style, onClick, flow]);
|
|
|
|
|
|
|
|
return itemElement;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default useItemElement;
|