| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- import { type JSX, useCallback, useEffect, useRef, useState } from 'react';
- import { useCurrentPageData } from '~/states/page';
- import { usePageControlsX } from '~/states/ui/page';
- import { PagePathHeader } from './PagePathHeader';
- import { PageTitleHeader } from './PageTitleHeader';
- import styles from './PageHeader.module.scss';
- const moduleClass = styles['page-header'] ?? '';
- export const PageHeader = (): JSX.Element => {
- const currentPage = useCurrentPageData();
- const pageControlsX = usePageControlsX();
- const pageHeaderRef = useRef<HTMLDivElement>(null);
- const [maxWidth, setMaxWidth] = useState<number>();
- const calcMaxWidth = useCallback(() => {
- if (pageControlsX == null || pageHeaderRef.current == null) {
- // Length that allows users to use PageHeader functionality.
- setMaxWidth(300);
- return;
- }
- // PageControls.x - PageHeader.x
- const maxWidth =
- pageControlsX - pageHeaderRef.current.getBoundingClientRect().x;
- setMaxWidth(maxWidth);
- }, [pageControlsX]);
- useEffect(() => {
- calcMaxWidth();
- }, [calcMaxWidth]);
- if (currentPage == null) {
- return <></>;
- }
- return (
- <div className={`${moduleClass} w-100`} ref={pageHeaderRef}>
- <PagePathHeader
- currentPage={currentPage}
- maxWidth={maxWidth}
- onRenameTerminated={calcMaxWidth}
- />
- <div className="mt-0 mt-md-1">
- <PageTitleHeader
- currentPage={currentPage}
- maxWidth={maxWidth}
- onMoveTerminated={calcMaxWidth}
- />
- </div>
- </div>
- );
- };
|