Skip to content

Commit

Permalink
fix footer
Browse files Browse the repository at this point in the history
  • Loading branch information
Brendonovich committed Nov 5, 2024
1 parent e5d10f5 commit fb3b136
Show file tree
Hide file tree
Showing 2 changed files with 165 additions and 163 deletions.
218 changes: 109 additions & 109 deletions src/default-theme/components/Article.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,113 +12,113 @@ import { useSolidBaseContext } from "../utils";
import styles from "./Article.module.css";

export default function Article(props: ParentProps) {
const { config } = useSolidBaseContext();

const { TableOfContents, Link, LastUpdated, Footer } = useThemeComponents();

const [contentRef, setContentRef] = createSignal<HTMLElement>();

const [clickedCodeElement, setClickedCodeElement] =
createSignal<HTMLElement>();

const pageData = useCurrentPageData();

createShortcut(
[isAppleDevice ? "Meta" : "Control", "A"],
(event) => {
// Only handle when code last clicked and no focus or copy button focused
if (
(clickedCodeElement() && document.activeElement === document.body) ||
(event?.target as HTMLElement | undefined)?.closest(
"div.expressive-code",
)
) {
const targetNode =
(event?.target as HTMLElement | undefined)?.closest(
"div.expressive-code",
) ?? clickedCodeElement()!;

if (window.getSelection()?.anchorNode === contentRef()) {
return; // Code already selected, select all (default) instead.
}

const range = document.createRange();
range.selectNode(targetNode);
window.getSelection()?.removeAllRanges();
window.getSelection()?.addRange(range);
event?.preventDefault();
}
},
{ preventDefault: false },
);

const onClick = (event: MouseEvent) => {
if (event.target) {
const closestCode = (event.target as HTMLElement).closest(
"div.expressive-code",
);
setClickedCodeElement(
(closestCode ?? undefined) as HTMLElement | undefined,
);
}
};

const prevNext = usePrevNext();

return (
<>
<WindowEventListener onClick={onClick} />

<article class={styles.article}>
<div ref={setContentRef} class={styles.content}>
{props.children}

<div class={styles.info}>
<Show when={pageData().editLink}>
<Link href={pageData().editLink}>Edit this page on GitHub</Link>
</Show>

<Show when={pageData().lastUpdated}>
<LastUpdated />
</Show>
</div>

<Show when={prevNext.prevLink() || prevNext.nextLink()}>
<nav class={styles.related}>
<div>
<Show when={prevNext.prevLink()}>
{(link) => (
<a class={styles.prev} href={link().link}>
<span>Previous</span>
{link().title}
</a>
)}
</Show>
</div>
<div>
<Show when={prevNext.nextLink()}>
{(link) => (
<a class={styles.next} href={link().link}>
<span>Next</span>
{link().title}
</a>
)}
</Show>
</div>
</nav>
</Show>

<Show when={config().themeConfig?.footer}>
<Footer />
</Show>
</div>

<Show when={!mobileLayout()}>
<aside class={styles.aside}>
<TableOfContents />
</aside>
</Show>
</article>
</>
);
const { config } = useSolidBaseContext();

const { TableOfContents, Link, LastUpdated, Footer } = useThemeComponents();

const [contentRef, setContentRef] = createSignal<HTMLElement>();

const [clickedCodeElement, setClickedCodeElement] =
createSignal<HTMLElement>();

const pageData = useCurrentPageData();

createShortcut(
[isAppleDevice ? "Meta" : "Control", "A"],
(event) => {
// Only handle when code last clicked and no focus or copy button focused
if (
(clickedCodeElement() && document.activeElement === document.body) ||
(event?.target as HTMLElement | undefined)?.closest(
"div.expressive-code",
)
) {
const targetNode =
(event?.target as HTMLElement | undefined)?.closest(
"div.expressive-code",
) ?? clickedCodeElement()!;

if (window.getSelection()?.anchorNode === contentRef()) {
return; // Code already selected, select all (default) instead.
}

const range = document.createRange();
range.selectNode(targetNode);
window.getSelection()?.removeAllRanges();
window.getSelection()?.addRange(range);
event?.preventDefault();
}
},
{ preventDefault: false },
);

const onClick = (event: MouseEvent) => {
if (event.target) {
const closestCode = (event.target as HTMLElement).closest(
"div.expressive-code",
);
setClickedCodeElement(
(closestCode ?? undefined) as HTMLElement | undefined,
);
}
};

const prevNext = usePrevNext();

return (
<>
<WindowEventListener onClick={onClick} />

<article class={styles.article}>
<div ref={setContentRef} class={styles.content}>
{props.children}

<div class={styles.info}>
<Show when={pageData().editLink}>
<Link href={pageData().editLink}>Edit this page on GitHub</Link>
</Show>

<Show when={pageData().lastUpdated}>
<LastUpdated />
</Show>
</div>

<Show when={prevNext.prevLink() || prevNext.nextLink()}>
<nav class={styles.related}>
<div>
<Show when={prevNext.prevLink()}>
{(link) => (
<a class={styles.prev} href={link().link}>
<span>Previous</span>
{link().title}
</a>
)}
</Show>
</div>
<div>
<Show when={prevNext.nextLink()}>
{(link) => (
<a class={styles.next} href={link().link}>
<span>Next</span>
{link().title}
</a>
)}
</Show>
</div>
</nav>
</Show>

<Show when={config().themeConfig?.footer ?? true}>
<Footer />
</Show>
</div>

<Show when={!mobileLayout()}>
<aside class={styles.aside}>
<TableOfContents />
</aside>
</Show>
</article>
</>
);
}
110 changes: 56 additions & 54 deletions src/default-theme/components/Footer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,70 +6,72 @@ import type { SocialLink } from "..";
import { useRouteConfig } from "../utils";

const logos: Partial<Record<SocialLink["type"], string>> = {
discord:
"",
github:
"",
opencollective:
"",
discord:
"",
github:
"",
opencollective:
"",
};

export default function Footer() {
const config = useRouteConfig();
const config = useRouteConfig();

return (
<footer class={styles.footer}>
<div>
<Show when={config().logo} fallback={<span>{config().title}</span>}>
<img src={config().logo} alt={config().title} />
</Show>
{config().description}
</div>
return (
<footer class={styles.footer}>
<div>
<Show when={config().logo} fallback={<span>{config().title}</span>}>
<img src={config().logo} alt={config().title} />
</Show>
{config().description}
</div>

<Show when={config().themeConfig?.socialLinks}>
{(links) => (
<div>
<span>Community</span>
<div class={styles.socials}>
<For each={Object.keys(links())}>
{(social) => {
const preset = Object.hasOwn(logos, social);
<Show when={config().themeConfig?.socialLinks}>
{(links) => (
<div>
<span>Community</span>
<div class={styles.socials}>
<For each={Object.keys(links())}>
{(social) => {
const preset = Object.hasOwn(logos, social);

const data = (): SocialLink => {
const data = preset
? {
type: social as SocialLink["type"],
// @ts-ignore
link: config().socialLinks[social],
}
: // @ts-ignore
config().socialLinks[social];
const data = (): SocialLink | undefined => {
const link = (links() as any)[social];
if (!link) return;

if (!preset) data.type = "custom";
const data = preset
? { type: social as SocialLink["type"], link }
: link;

return data;
};
if (!preset) data.type = "custom";

return <SocialLinkView {...data()} />;
}}
</For>
</div>
</div>
)}
</Show>
</footer>
);
return data;
};

return (
<Show when={data()}>
{(data) => <SocialLinkView {...data()} />}
</Show>
);
}}
</For>
</div>
</div>
)}
</Show>
</footer>
);
}

function SocialLinkView(props: SocialLink) {
return (
<a href={props.link} target="_blank" rel="noreferrer noopener">
<Show
when={props.type !== "custom"}
fallback={<img alt={props.label} src={props.logo} />}
>
<img alt={props.type} src={logos[props.type as keyof typeof logos]} />
</Show>
</a>
);
return (
<a href={props.link} target="_blank" rel="noreferrer noopener">
<Show
when={props.type !== "custom"}
fallback={<img alt={props.label} src={props.logo} />}
>
<img alt={props.type} src={logos[props.type as keyof typeof logos]} />
</Show>
</a>
);
}

0 comments on commit fb3b136

Please sign in to comment.