Skip to content

Commit

Permalink
(refactor) Add background color on scrolling sticky results menu
Browse files Browse the repository at this point in the history
  • Loading branch information
CynthiaKamau committed Sep 19, 2024
1 parent dd6614b commit 2523c5d
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -83,9 +83,6 @@ function renderAddLabOrderWorkspace() {
promptBeforeClosing={mockPromptBeforeClosing}
patientUuid={ptUuid}
setTitle={jest.fn()}
setCancelTitle={jest.fn()}
setCancelMessage={jest.fn()}
setCancelConfirmText={jest.fn()}
/>,
);
return { mockCloseWorkspace, mockPromptBeforeClosing, mockCloseWorkspaceWithSavedChanges, ...view };
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,9 +85,6 @@ export default function AddLabOrderWorkspace({
closeWorkspaceWithSavedChanges={closeWorkspaceWithSavedChanges}
promptBeforeClosing={promptBeforeClosing}
setTitle={() => {}}
setCancelTitle={() => {}}
setCancelMessage={() => {}}
setCancelConfirmText={() => {}}
/>
)}
</div>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, { useCallback, useContext, useState } from 'react';
import React, { useCallback, useContext, useEffect, useRef, useState } from 'react';
import classNames from 'classnames';
import { type TFunction, useTranslation } from 'react-i18next';
import { useParams } from 'react-router-dom';
Expand All @@ -15,6 +15,7 @@ import Trendline from '../trendline/trendline.component';
import type { ConfigObject } from '../../config-schema';
import styles from './results-viewer.scss';
import { type viewOpts } from '../../types';
import debounce from 'lodash-es/debounce';

type panelOpts = 'tree' | 'panel';

Expand Down Expand Up @@ -65,6 +66,34 @@ const ResultsViewer: React.FC<ResultsViewerProps> = ({ patientUuid, basePath, lo
const isExpanded = view === 'full';
const trendlineView = testUuid && type === 'trendline';
const responsiveSize = isTablet ? 'lg' : 'md';
const [showStickyHeader, setShowStickyHeader] = useState(false);
const headerRef = useRef(null);
const headerPositionRef = useRef(0);

useEffect(() => {
const setInitialPosition = () => {
if (headerRef.current) {
headerPositionRef.current = headerRef.current.getBoundingClientRect().top + window.scrollY;
}
};

setInitialPosition();

const handleScroll = () => {
if (headerRef.current) {
const scrollPosition = window.scrollY;
setShowStickyHeader(scrollPosition > headerPositionRef.current);
}
};

window.addEventListener('scroll', handleScroll);
window.addEventListener('resize', setInitialPosition);

return () => {
window.removeEventListener('scroll', handleScroll);
window.removeEventListener('resize', setInitialPosition);
};
}, []);

const navigateBackFromTrendlineView = useCallback(() => {
navigate({
Expand Down Expand Up @@ -123,7 +152,11 @@ const ResultsViewer: React.FC<ResultsViewerProps> = ({ patientUuid, basePath, lo

return (
<div className={styles.resultsContainer}>
<div className={styles.resultsHeader}>
<div
ref={headerRef}
id="data-element-sticky"
className={classNames(styles.resultsHeader, { [styles.stickyResultsHeader]: showStickyHeader })}
>
<div className={classNames(styles.leftSection, styles.leftHeaderSection)}>
<h4>{t('tests', 'Tests')}</h4>
<Button
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,9 +43,14 @@
padding: layout.$spacing-03 0;
z-index: 10;
background-color: $openmrs-background-grey;
position: sticky;
top: layout.$spacing-09;
display: flex;
position: sticky;
}

.stickyResultsHeader {
@extend .resultsHeader;
border-bottom: 1px solid #e1e1e1;
}

.leftHeaderSection {
Expand Down

0 comments on commit 2523c5d

Please sign in to comment.