Skip to content

Commit

Permalink
Connected navigation and editor panel
Browse files Browse the repository at this point in the history
  • Loading branch information
vipinpaul committed Jan 4, 2024
1 parent dee45f0 commit b4e45d7
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 9 deletions.
30 changes: 27 additions & 3 deletions renderer/src/components/EditorPage/TextEditor/Editor.jsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
import React, { useContext, useEffect } from 'react';
import React, {
useContext, useEffect, useLayoutEffect, useRef,
} from 'react';
import { HtmlPerfEditor } from '@xelah/type-perf-html';

import LoadingScreen from '@/components/Loading/LoadingScreen';
Expand All @@ -12,7 +14,7 @@ import { functionMapping } from './utils/insertFunctionMap';
import RecursiveBlock from './RecursiveBlock';
// eslint-disable-next-line import/no-unresolved, import/extensions
import { useAutoSaveIndication } from '@/hooks2/useAutoSaveIndication';
import { onIntersection } from './utils/IntersectionObserver';
import { onIntersection, scrollReference } from './utils/IntersectionObserver';

export default function Editor(props) {
const {
Expand Down Expand Up @@ -98,14 +100,35 @@ export default function Editor(props) {
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [triggerVerseInsert]);

const isScrolling = useRef(false);
useLayoutEffect(() => {
const handleScroll = () => {
isScrolling.current = true;
};
const handleScrollEnd = () => {
isScrolling.current = false;
};
const editorDiv = document.getElementById('fulleditor');
// Adding scroll and click event listeners
editorDiv.addEventListener('scroll', handleScroll);
editorDiv.addEventListener('click', handleScrollEnd);
return () => {
editorDiv.removeEventListener('scroll', handleScroll);
editorDiv.removeEventListener('click', handleScrollEnd);
};
}, []);

useAutoSaveIndication(isSaving);

function onReferenceSelected({ chapter, verse }) {
chapter && setChapterNumber(chapter);
verse && setVerseNumber(verse);
scrollReference(chapter);
}

const observer = new IntersectionObserver((entries) => onIntersection({ setChapterNumber, scrollLock, entries }), {
const observer = new IntersectionObserver((entries) => onIntersection({
scroll: isScrolling.current, setChapterNumber, scrollLock, entries, setVerseNumber,
}), {
root: document.querySelector('editor'),
threshold: 0,
rootMargin: '0% 0% -60% 0%',
Expand Down Expand Up @@ -140,6 +163,7 @@ export default function Editor(props) {

return (
<div
id="fulleditor"
style={{
fontFamily: selectedFont || 'sans-serif',
fontSize: `${fontSize}rem`,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,17 @@ export const scrollReference = (chapterNumber) => {
});
};

export const onIntersection = ({ entries, setChapterNumber, scrollLock }) => {
// eslint-disable-next-line no-restricted-syntax
for (const entry of entries) {
if (entry.isIntersecting) {
setChapterNumber(entry.target.dataset.attsNumber);
scrollLock === false ? scrollReference(entry.target.dataset.attsNumber) : {};
export const onIntersection = ({
scroll, entries, setChapterNumber, scrollLock, setVerseNumber,
}) => {
if (scroll) {
// eslint-disable-next-line no-restricted-syntax
for (const entry of entries) {
if (entry.isIntersecting) {
setChapterNumber(entry.target.dataset.attsNumber);
setVerseNumber(1);
scrollLock === false ? scrollReference(entry.target.dataset.attsNumber) : {};
}
}
}
};

0 comments on commit b4e45d7

Please sign in to comment.