Skip to content

Commit

Permalink
fix: useEffect is invalid
Browse files Browse the repository at this point in the history
  • Loading branch information
callqh committed Oct 4, 2022
1 parent 52298a7 commit 6495e07
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 33 deletions.
6 changes: 0 additions & 6 deletions src/theme-default/layout/DocLayout/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ import { DocFooter } from '../../components/DocFooter/index';
import { Content, usePageData } from 'island/client';
import { useLocaleSiteData } from '../../logic';
import { useLocation } from 'react-router-dom';
import { setupCopyCodeButton } from '../../logic';
import { useEffect } from 'react';

export function DocLayout() {
const { toc: headers = [], siteData, pagePath } = usePageData();
Expand All @@ -23,10 +21,6 @@ export function DocLayout() {

const hasAside = headers.length > 0 && themeConfig.outline !== false;

useEffect(() => {
setupCopyCodeButton();
}, []);

return (
<div p="t-0 x-6 b-24 sm:6">
{hasSidebar ? <SideBar /> : null}
Expand Down
50 changes: 23 additions & 27 deletions src/theme-default/logic/copyCode.ts
Original file line number Diff line number Diff line change
@@ -1,34 +1,30 @@
import { inBrowser } from '../../shared/utils';

export function setupCopyCodeButton() {
if (inBrowser()) {
const timeoutIdMap: Map<HTMLElement, NodeJS.Timeout> = new Map();
window.addEventListener('click', (e) => {
const el = e.target as HTMLElement;
const timeoutIdMap: Map<HTMLElement, NodeJS.Timeout> = new Map();
window.addEventListener('click', (e) => {
const el = e.target as HTMLElement;

if (el.matches('div[class*="language-"] > button.copy')) {
const parent = el.parentElement;
const sibling = el.nextElementSibling
?.nextElementSibling as HTMLPreElement | null;
if (!parent || !sibling) {
return;
}
if (el.matches('div[class*="language-"] > button.copy')) {
const parent = el.parentElement;
const sibling = el.nextElementSibling
?.nextElementSibling as HTMLPreElement | null;
if (!parent || !sibling) {
return;
}

const { innerText: text = '' } = sibling;
const { innerText: text = '' } = sibling;

copyToClipboard(text).then(() => {
el.classList.add('copied');
clearTimeout(timeoutIdMap.get(el));
const timeoutId = setTimeout(() => {
el.classList.remove('copied');
el.blur();
timeoutIdMap.delete(el);
}, 2000);
timeoutIdMap.set(el, timeoutId);
});
}
});
}
copyToClipboard(text).then(() => {
el.classList.add('copied');
clearTimeout(timeoutIdMap.get(el));
const timeoutId = setTimeout(() => {
el.classList.remove('copied');
el.blur();
timeoutIdMap.delete(el);
}, 2000);
timeoutIdMap.set(el, timeoutId);
});
}
});
}

async function copyToClipboard(text: string) {
Expand Down
2 changes: 2 additions & 0 deletions src/theme-default/logic/sideEffects.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { throttle } from 'lodash-es';
import { APPEARANCE_KEY } from '../../shared/constants';
import { inBrowser } from '../../shared/utils';
import { setupCopyCodeButton } from './copyCode';

const DEFAULT_NAV_HEIGHT = 60;

Expand Down Expand Up @@ -209,4 +210,5 @@ export function setupEffects() {
bindingAsideScroll();
}
bindingWindowScroll();
setupCopyCodeButton();
}

0 comments on commit 6495e07

Please sign in to comment.