Skip to content

Commit

Permalink
Hide In this page -sidebar from the browser search
Browse files Browse the repository at this point in the history
  • Loading branch information
Maija Y committed Nov 16, 2023
1 parent b6bda05 commit 7fb8f17
Showing 1 changed file with 72 additions and 69 deletions.
141 changes: 72 additions & 69 deletions services/course-material/src/components/HeadingsNavigation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -238,82 +238,85 @@ const HeadingsNavigation: React.FC<React.PropsWithChildren<HeadingsNavigationPro
`}
aria-hidden={Boolean(realCollapsed)}
>
<h3
className={css`
font-size: 16px;
color: ${baseTheme.colors.gray[600]};
font-weight: 700;
display: inline;
position: relative;
left: -2px;
bottom: -3px;
`}
>
{t("in-this-page")}
</h3>

<StyledTopics role="navigation">
{!realCollapsed && (
<div>
{headings &&
headings.map(({ headingsNavigationIndex, title, element }) => {
return (
<button
className={css`
border: none;
background: unset;
text-align: left;
width: 100%;
padding: 0;
`}
tabIndex={realCollapsed ? -1 : 0}
key={headingsNavigationIndex}
onClick={(e) => {
e.preventDefault()
try {
// Atomic, since Javascript is single-threaded
numberOfCallbacksScrollingTheDocument.current += 1
setActiveHeading(headingsNavigationIndex)
<h3
className={css`
font-size: 16px;
color: ${baseTheme.colors.gray[600]};
font-weight: 700;
display: inline;
position: relative;
left: -2px;
bottom: -3px;
`}
>
{t("in-this-page")}
</h3>
<StyledTopics role="navigation">
<div>
{headings &&
headings.map(({ headingsNavigationIndex, title, element }) => {
return (
<button
className={css`
border: none;
background: unset;
text-align: left;
width: 100%;
padding: 0;
`}
tabIndex={realCollapsed ? -1 : 0}
key={headingsNavigationIndex}
onClick={(e) => {
e.preventDefault()
try {
// Atomic, since Javascript is single-threaded
numberOfCallbacksScrollingTheDocument.current += 1
setActiveHeading(headingsNavigationIndex)

// Better to use to use the parent provided by the block -- it makes scrolling to hero section to reveal the whole block
const blockElement =
element.closest(`.${courseMaterialBlockClass}`) || element
// Better to use to use the parent provided by the block -- it makes scrolling to hero section to reveal the whole block
const blockElement =
element.closest(`.${courseMaterialBlockClass}`) || element

// we have to calculate the position of the element because it might have moved.
const elementYCoordinateRelativeToViewport =
blockElement.getBoundingClientRect().top
const top = elementYCoordinateRelativeToViewport + window.scrollY
window.scrollTo({
top: top + HEADING_SCROLL_DESTINATION_START_OFFSET_PX,
behavior: "smooth",
})
} finally {
// We don't know when the scroll animation is done, so we'll guess
// The timeout has to be unfortunately long because the scroll animation may take quite some time
setTimeout(() => {
// Atomic, since Javascript is single-threaded
numberOfCallbacksScrollingTheDocument.current -= 1
// Since we have skipped updating the active heading indicator for some time, it's a good idea to update it now
onScrollCallback2()
}, 3000)
}
}}
>
<StTopic
className={css`
${activeHeading === headingsNavigationIndex &&
`background: #DAE6E5;
// we have to calculate the position of the element because it might have moved.
const elementYCoordinateRelativeToViewport =
blockElement.getBoundingClientRect().top
const top = elementYCoordinateRelativeToViewport + window.scrollY
window.scrollTo({
top: top + HEADING_SCROLL_DESTINATION_START_OFFSET_PX,
behavior: "smooth",
})
} finally {
// We don't know when the scroll animation is done, so we'll guess
// The timeout has to be unfortunately long because the scroll animation may take quite some time
setTimeout(() => {
// Atomic, since Javascript is single-threaded
numberOfCallbacksScrollingTheDocument.current -= 1
// Since we have skipped updating the active heading indicator for some time, it's a good idea to update it now
onScrollCallback2()
}, 3000)
}
}}
>
<StTopic
className={css`
${activeHeading === headingsNavigationIndex &&
`background: #DAE6E5;
&:before{
background: #1F6964 !important
}`}
`}
>
<div>{title}</div>
</StTopic>
</button>
)
})}
`}
>
<div>{title}</div>
</StTopic>
</button>
)
})}
</div>
</StyledTopics>
</div>
</StyledTopics>
)}
</div>

<button
Expand Down

0 comments on commit 7fb8f17

Please sign in to comment.