@prose-reader/react-reader 1.187.0 → 1.188.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dist/{src/ReactReader.d.ts → ReactReader.d.ts} +2 -3
  2. package/dist/annotations/AnnotationsDialog.d.ts +5 -0
  3. package/dist/annotations/AnnotationsDialogContent.d.ts +3 -0
  4. package/dist/bookmarks/BookmarksDialog.d.ts +5 -0
  5. package/dist/bookmarks/BookmarksDialogContent.d.ts +3 -0
  6. package/dist/context/useReader.d.ts +8 -0
  7. package/dist/index.js +695 -568
  8. package/dist/index.js.map +1 -1
  9. package/dist/index.umd.cjs +1 -1
  10. package/dist/index.umd.cjs.map +1 -1
  11. package/dist/quickmenu/BottomBar.d.ts +4 -0
  12. package/dist/quickmenu/QuickMenu.d.ts +3 -0
  13. package/dist/quickmenu/Scrubber.d.ts +3 -0
  14. package/dist/quickmenu/TopBar.d.ts +4 -0
  15. package/dist/theme/config.d.ts +1 -0
  16. package/package.json +11 -2
  17. package/dist/src/context/useReader.d.ts +0 -4
  18. package/dist/src/navigation/QuickMenu/BottomBar.d.ts +0 -6
  19. package/dist/src/navigation/QuickMenu/QuickMenu.d.ts +0 -7
  20. package/dist/src/navigation/QuickMenu/Scrubber.d.ts +0 -1
  21. package/dist/src/navigation/QuickMenu/TopBar.d.ts +0 -5
  22. /package/dist/{src/common → common}/useFullscreen.d.ts +0 -0
  23. /package/dist/{src/components → components}/ui/accordion.d.ts +0 -0
  24. /package/dist/{src/components → components}/ui/avatar.d.ts +0 -0
  25. /package/dist/{src/components → components}/ui/checkbox.d.ts +0 -0
  26. /package/dist/{src/components → components}/ui/close-button.d.ts +0 -0
  27. /package/dist/{src/components → components}/ui/color-mode.d.ts +0 -0
  28. /package/dist/{src/components → components}/ui/dialog.d.ts +0 -0
  29. /package/dist/{src/components → components}/ui/drawer.d.ts +0 -0
  30. /package/dist/{src/components → components}/ui/field.d.ts +0 -0
  31. /package/dist/{src/components → components}/ui/input-group.d.ts +0 -0
  32. /package/dist/{src/components → components}/ui/popover.d.ts +0 -0
  33. /package/dist/{src/components → components}/ui/progress.d.ts +0 -0
  34. /package/dist/{src/components → components}/ui/provider.d.ts +0 -0
  35. /package/dist/{src/components → components}/ui/radio.d.ts +0 -0
  36. /package/dist/{src/components → components}/ui/slider.d.ts +0 -0
  37. /package/dist/{src/components → components}/ui/toggle-tip.d.ts +0 -0
  38. /package/dist/{src/components → components}/ui/tooltip.d.ts +0 -0
  39. /package/dist/{src/context → context}/ReactReaderProvider.d.ts +0 -0
  40. /package/dist/{src/context → context}/context.d.ts +0 -0
  41. /package/dist/{src/help → help}/HelpDialog.d.ts +0 -0
  42. /package/dist/{src/index.d.ts → index.d.ts} +0 -0
  43. /package/dist/{src/navigation → navigation}/FloatingProgress.d.ts +0 -0
  44. /package/dist/{src/navigation → navigation}/FloatingTime.d.ts +0 -0
  45. /package/dist/{src/navigation → navigation}/useNavigationContext.d.ts +0 -0
  46. /package/dist/{src/pagination → pagination}/usePagination.d.ts +0 -0
  47. /package/dist/{src/navigation/QuickMenu → quickmenu}/PaginationInfoSection.d.ts +0 -0
  48. /package/dist/{src/navigation/QuickMenu → quickmenu}/QuickBar.d.ts +0 -0
  49. /package/dist/{src/navigation/QuickMenu → quickmenu}/ThemedSlider.d.ts +0 -0
  50. /package/dist/{src/navigation/QuickMenu → quickmenu}/TimeIndicator.d.ts +0 -0
  51. /package/dist/{src/navigation/QuickMenu → quickmenu}/useQuickMenu.d.ts +0 -0
  52. /package/dist/{src/search → search}/SearchDialog.d.ts +0 -0
  53. /package/dist/{src/search → search}/SearchDialogContent.d.ts +0 -0
  54. /package/dist/{src/search → search}/SearchListItem.d.ts +0 -0
  55. /package/dist/{src/settings → settings}/useSettings.d.ts +0 -0
  56. /package/dist/{src/toc → toc}/TableOfContentsDialog.d.ts +0 -0
  57. /package/dist/{src/toc → toc}/TableOfContentsDialogContent.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"index.umd.cjs","sources":["../src/context/context.ts","../src/context/ReactReaderProvider.tsx","../src/components/ui/close-button.tsx","../src/components/ui/dialog.tsx","../src/help/HelpDialog.tsx","../src/context/useReader.ts","../src/pagination/usePagination.ts","../src/navigation/FloatingProgress.tsx","../src/navigation/QuickMenu/TimeIndicator.tsx","../src/navigation/QuickMenu/useQuickMenu.ts","../src/navigation/FloatingTime.tsx","../src/components/ui/toggle-tip.tsx","../src/components/ui/progress.tsx","../src/navigation/useNavigationContext.ts","../src/navigation/QuickMenu/PaginationInfoSection.tsx","../src/navigation/QuickMenu/QuickBar.tsx","../src/navigation/QuickMenu/ThemedSlider.tsx","../src/navigation/QuickMenu/Scrubber.tsx","../src/navigation/QuickMenu/BottomBar.tsx","../src/common/useFullscreen.ts","../src/navigation/QuickMenu/TopBar.tsx","../src/navigation/QuickMenu/QuickMenu.tsx","../src/search/SearchListItem.tsx","../src/search/SearchDialogContent.tsx","../src/search/SearchDialog.tsx","../src/toc/TableOfContentsDialogContent.tsx","../src/toc/TableOfContentsDialog.tsx","../src/ReactReader.tsx"],"sourcesContent":["import type { Reader } from \"@prose-reader/core\"\nimport { type Context, createContext } from \"react\"\nimport { type Signal, signal } from \"reactjrx\"\n\ntype ContextType = {\n reader: Reader | undefined\n quickMenuSignal: Signal<boolean, boolean, undefined>\n}\n\nexport const ReaderContext: Context<ContextType> = createContext<ContextType>({\n reader: undefined,\n quickMenuSignal: signal({ default: false }),\n})\n","import type { Reader } from \"@prose-reader/core\"\nimport { memo, useEffect, useMemo } from \"react\"\nimport { useLiveRef, useSignal, useSubscribe } from \"reactjrx\"\nimport { tap } from \"rxjs\"\nimport { ReaderContext } from \"./context\"\n\nexport const ReactReaderProvider = memo(\n ({\n children,\n reader,\n quickMenuOpen,\n onQuickMenuOpenChange,\n }: {\n children?: React.ReactNode\n reader: Reader | undefined\n quickMenuOpen: boolean\n onQuickMenuOpenChange: (open: boolean) => void\n }) => {\n const [, quickMenuSignal] = useSignal({\n default: quickMenuOpen,\n })\n const onQuickMenuOpenChangeLiveRef = useLiveRef(onQuickMenuOpenChange)\n\n const value = useMemo(\n () => ({\n quickMenuSignal,\n reader,\n }),\n [quickMenuSignal, reader],\n )\n\n useEffect(() => {\n quickMenuSignal.setValue(quickMenuOpen)\n }, [quickMenuOpen, quickMenuSignal])\n\n useSubscribe(\n () =>\n quickMenuSignal.subject.pipe(tap(onQuickMenuOpenChangeLiveRef.current)),\n [quickMenuSignal, onQuickMenuOpenChangeLiveRef],\n )\n\n return (\n <ReaderContext.Provider value={value}>{children}</ReaderContext.Provider>\n )\n },\n)\n","import type { ButtonProps } from \"@chakra-ui/react\"\nimport { IconButton as ChakraIconButton } from \"@chakra-ui/react\"\nimport * as React from \"react\"\nimport { LuX } from \"react-icons/lu\"\n\nexport type CloseButtonProps = ButtonProps\n\nexport const CloseButton = React.forwardRef<\n HTMLButtonElement,\n CloseButtonProps\n>(function CloseButton(props, ref) {\n return (\n <ChakraIconButton variant=\"ghost\" aria-label=\"Close\" ref={ref} {...props}>\n {props.children ?? <LuX />}\n </ChakraIconButton>\n )\n})\n","import { Dialog as ChakraDialog, Portal } from \"@chakra-ui/react\"\nimport { CloseButton } from \"./close-button\"\nimport * as React from \"react\"\n\ninterface DialogContentProps extends ChakraDialog.ContentProps {\n portalled?: boolean\n portalRef?: React.RefObject<HTMLElement>\n backdrop?: boolean\n}\n\nexport const DialogContent = React.forwardRef<\n HTMLDivElement,\n DialogContentProps\n>(function DialogContent(props, ref) {\n const {\n children,\n portalled = true,\n portalRef,\n backdrop = true,\n ...rest\n } = props\n\n return (\n <Portal disabled={!portalled} container={portalRef}>\n {backdrop && <ChakraDialog.Backdrop />}\n <ChakraDialog.Positioner>\n <ChakraDialog.Content ref={ref} {...rest} asChild={false}>\n {children}\n </ChakraDialog.Content>\n </ChakraDialog.Positioner>\n </Portal>\n )\n})\n\nexport const DialogCloseTrigger = React.forwardRef<\n HTMLButtonElement,\n ChakraDialog.CloseTriggerProps\n>(function DialogCloseTrigger(props, ref) {\n return (\n <ChakraDialog.CloseTrigger\n position=\"absolute\"\n top=\"2\"\n insetEnd=\"2\"\n {...props}\n asChild\n >\n <CloseButton size=\"sm\" ref={ref}>\n {props.children}\n </CloseButton>\n </ChakraDialog.CloseTrigger>\n )\n})\n\nexport const DialogRoot = ChakraDialog.Root\nexport const DialogFooter = ChakraDialog.Footer\nexport const DialogHeader = ChakraDialog.Header\nexport const DialogBody = ChakraDialog.Body\nexport const DialogBackdrop = ChakraDialog.Backdrop\nexport const DialogTitle = ChakraDialog.Title\nexport const DialogDescription = ChakraDialog.Description\nexport const DialogTrigger = ChakraDialog.Trigger\nexport const DialogActionTrigger = ChakraDialog.ActionTrigger\n","import { Button, HStack, Heading, Kbd, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport { LuArrowBigLeft, LuArrowBigRight } from \"react-icons/lu\"\nimport { name, version } from \"../../package.json\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\n\nexport const HelpDialog = memo(\n ({\n open,\n setOpen,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Help</DialogTitle>\n </DialogHeader>\n <DialogBody overflowY=\"auto\" flex={1}>\n <Heading mb={2} as=\"h3\" size=\"lg\">\n Shortcuts\n </Heading>\n <HStack mb={1}>\n <Kbd>\n <LuArrowBigRight />\n </Kbd>{\" \"}\n <Text>Navigate to right page</Text>\n </HStack>\n <HStack mb={1}>\n <Kbd>\n <LuArrowBigLeft />\n </Kbd>{\" \"}\n <Text>Navigate to left page</Text>\n </HStack>\n <Heading mb={2} mt={4} as=\"h3\" size=\"lg\">\n About\n </Heading>\n <Text>\n {name} version: {version}\n </Text>\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import type { Reader } from \"@prose-reader/core\"\nimport type { SearchEnhancerAPI } from \"@prose-reader/enhancer-search\"\nimport { useContext } from \"react\"\nimport { ReaderContext } from \"./context\"\n\nexport const useReader = (): Reader | undefined => {\n const { reader } = useContext(ReaderContext)\n\n return reader\n}\n\nexport const hasSearchEnhancer = (\n reader?: Reader,\n): reader is Reader & SearchEnhancerAPI => {\n return !!reader && \"__PROSE_READER_ENHANCER_SEARCH\" in reader\n}\n","import type { Reader } from \"@prose-reader/core\"\nimport { useObserve } from \"reactjrx\"\nimport { NEVER, combineLatest, map } from \"rxjs\"\nimport { useReader } from \"../context/useReader\"\n\nexport const usePagination = ():\n | (Reader[\"pagination\"][\"state\"] & { hasChapters: boolean })\n | undefined => {\n const reader = useReader()\n\n return useObserve(\n () =>\n !reader\n ? NEVER\n : combineLatest([reader.pagination.state$, reader.context.state$]).pipe(\n map(([state, context]) => {\n const isOnlyImages = context.manifest?.spineItems.every((item) =>\n item.mediaType?.startsWith(\"image/\"),\n )\n\n return {\n ...state,\n hasChapters: !context.isFullyPrePaginated && !isOnlyImages,\n }\n }),\n ),\n [reader],\n )\n}\n","import { Box, Text } from \"@chakra-ui/react\"\nimport { usePagination } from \"../pagination/usePagination\"\n\nexport const FloatingProgress = () => {\n const pagination = usePagination()\n const roundedProgress = Math.floor(\n (pagination?.percentageEstimateOfBook ?? 0) * 100,\n )\n const displayableProgress = roundedProgress > 0 ? roundedProgress : 1\n\n if (pagination?.percentageEstimateOfBook === undefined) return null\n\n return (\n <Box position=\"absolute\" right={0} bottom={0} p={2} color={\"black\"}>\n <Text fontSize=\"sm\">{displayableProgress} %</Text>\n </Box>\n )\n}\n","import { Text, type TextProps } from \"@chakra-ui/react\"\nimport { useEffect, useState } from \"react\"\n\nexport const useTime = () => {\n const [time, setTime] = useState(new Date())\n\n useEffect(() => {\n const interval = setInterval(() => {\n setTime(new Date())\n }, 1000 * 60)\n\n return () => clearInterval(interval)\n }, [])\n\n return time\n}\n\nexport const TimeIndicator = (props: TextProps) => {\n const time = useTime()\n\n return (\n <Text fontSize=\"xs\" {...props}>\n {time.toLocaleTimeString(navigator.language, {\n hour: \"2-digit\",\n minute: \"2-digit\",\n })}\n </Text>\n )\n}\n","import { useContext } from \"react\"\nimport { useSignalValue } from \"reactjrx\"\nimport { ReaderContext } from \"../../context/context\"\n\nexport const useQuickMenu = () => {\n const { quickMenuSignal } = useContext(ReaderContext)\n\n const quickMenu = useSignalValue(quickMenuSignal)\n\n return [quickMenu, quickMenuSignal.setValue, quickMenuSignal] as const\n}\n","import { Box } from \"@chakra-ui/react\"\nimport { TimeIndicator } from \"./QuickMenu/TimeIndicator\"\nimport { useQuickMenu } from \"./QuickMenu/useQuickMenu\"\n\nexport const FloatingTime = () => {\n const [quickMenuOpen] = useQuickMenu()\n\n return (\n <Box\n position=\"absolute\"\n left={0}\n bottom={0}\n p={2}\n color={quickMenuOpen ? undefined : \"colorPalette.contrast\"}\n >\n <TimeIndicator />\n </Box>\n )\n}\n","import { Popover as ChakraPopover, IconButton, Portal } from \"@chakra-ui/react\"\nimport * as React from \"react\"\nimport { HiOutlineInformationCircle } from \"react-icons/hi\"\n\nexport interface ToggleTipProps extends ChakraPopover.RootProps {\n showArrow?: boolean\n portalled?: boolean\n portalRef?: React.RefObject<HTMLElement>\n content?: React.ReactNode\n}\n\nexport const ToggleTip = React.forwardRef<HTMLDivElement, ToggleTipProps>(\n function ToggleTip(props, ref) {\n const {\n showArrow,\n children,\n portalled = true,\n content,\n portalRef,\n ...rest\n } = props\n\n return (\n <ChakraPopover.Root\n {...rest}\n positioning={{ ...rest.positioning, gutter: 4 }}\n >\n <ChakraPopover.Trigger asChild>{children}</ChakraPopover.Trigger>\n <Portal disabled={!portalled} container={portalRef}>\n <ChakraPopover.Positioner>\n <ChakraPopover.Content\n width=\"auto\"\n px=\"2\"\n py=\"1\"\n textStyle=\"xs\"\n rounded=\"sm\"\n ref={ref}\n >\n {showArrow && (\n <ChakraPopover.Arrow>\n <ChakraPopover.ArrowTip />\n </ChakraPopover.Arrow>\n )}\n {content}\n </ChakraPopover.Content>\n </ChakraPopover.Positioner>\n </Portal>\n </ChakraPopover.Root>\n )\n },\n)\n\nexport const InfoTip = React.forwardRef<\n HTMLDivElement,\n Partial<ToggleTipProps>\n>(function InfoTip(props, ref) {\n const { children, ...rest } = props\n return (\n <ToggleTip content={children} {...rest} ref={ref}>\n <IconButton\n variant=\"ghost\"\n aria-label=\"info\"\n size=\"2xs\"\n colorPalette=\"gray\"\n >\n <HiOutlineInformationCircle />\n </IconButton>\n </ToggleTip>\n )\n})\n","import { Progress as ChakraProgress } from \"@chakra-ui/react\"\nimport { InfoTip } from \"./toggle-tip\"\nimport * as React from \"react\"\n\nexport const ProgressBar = React.forwardRef<\n HTMLDivElement,\n ChakraProgress.TrackProps\n>(function ProgressBar(props, ref) {\n return (\n <ChakraProgress.Track {...props} ref={ref}>\n <ChakraProgress.Range />\n </ChakraProgress.Track>\n )\n})\n\nexport interface ProgressLabelProps extends ChakraProgress.LabelProps {\n info?: React.ReactNode\n}\n\nexport const ProgressLabel = React.forwardRef<\n HTMLDivElement,\n ProgressLabelProps\n>(function ProgressLabel(props, ref) {\n const { children, info, ...rest } = props\n return (\n <ChakraProgress.Label {...rest} ref={ref}>\n {children}\n {info && <InfoTip>{info}</InfoTip>}\n </ChakraProgress.Label>\n )\n})\n\nexport const ProgressRoot = ChakraProgress.Root\nexport const ProgressValueText = ChakraProgress.ValueText\n","import { usePagination } from \"../pagination/usePagination\"\n\nexport const useNavigationContext = () => {\n const pagination = usePagination()\n const hasOnlyOnePage = pagination?.numberOfTotalPages === 1\n\n const isBeginWithinChapter =\n (pagination?.beginNumberOfPagesInSpineItem ?? 0) > 1\n\n const isEndWithinChapter = (pagination?.endNumberOfPagesInSpineItem ?? 0) > 1\n\n const beginPageIndex =\n (pagination?.hasChapters\n ? pagination?.beginPageIndexInSpineItem\n : pagination?.beginAbsolutePageIndex) ?? 0\n const endPageIndex =\n (pagination?.hasChapters\n ? pagination?.endPageIndexInSpineItem\n : pagination?.endAbsolutePageIndex) ?? 0\n\n const [leftPageIndex = 0, rightPageIndex = 0] = [\n beginPageIndex,\n endPageIndex,\n ].sort((a, b) => a - b)\n\n const beginAndEndAreDifferent =\n pagination?.beginPageIndexInSpineItem !==\n pagination?.endPageIndexInSpineItem ||\n pagination?.beginSpineItemIndex !== pagination?.endSpineItemIndex\n\n const totalApproximatePages = pagination?.hasChapters\n ? pagination?.beginNumberOfPagesInSpineItem\n : pagination?.numberOfTotalPages\n\n return {\n hasOnlyOnePage,\n beginPageIndex,\n endPageIndex,\n isBeginWithinChapter,\n isEndWithinChapter,\n beginAndEndAreDifferent,\n totalApproximatePages,\n leftPageIndex,\n rightPageIndex,\n }\n}\n","import { HStack, Stack, Text } from \"@chakra-ui/react\"\nimport {\n ProgressBar,\n ProgressRoot,\n ProgressValueText,\n} from \"../../components/ui/progress\"\nimport { usePagination } from \"../../pagination/usePagination\"\nimport { useNavigationContext } from \"../useNavigationContext\"\n\nexport const PaginationInfoSection = () => {\n const pagination = usePagination()\n const {\n hasOnlyOnePage,\n leftPageIndex,\n rightPageIndex,\n totalApproximatePages,\n beginAndEndAreDifferent,\n } = useNavigationContext()\n const progress = Math.round((pagination?.percentageEstimateOfBook ?? 0) * 100)\n\n const buildTitleChain = (\n chapterInfo: NonNullable<typeof pagination>[\"beginChapterInfo\"],\n ): string => {\n if (chapterInfo?.subChapter) {\n return `${chapterInfo.title} / ${buildTitleChain(chapterInfo.subChapter)}`\n }\n return chapterInfo?.title || \"\"\n }\n\n const chapterTitle = buildTitleChain(pagination?.beginChapterInfo)\n\n return (\n <Stack alignItems=\"center\" gap={1} maxW=\"100%\" overflow=\"auto\">\n <ProgressRoot value={progress} size=\"xs\" width={150}>\n <HStack justifyContent=\"space-between\">\n <ProgressBar width={110} />\n <ProgressValueText>{`${progress}%`}</ProgressValueText>\n </HStack>\n </ProgressRoot>\n <Text truncate maxWidth=\"100%\" fontSize=\"sm\" mt={1}>\n {chapterTitle ? `Chapter: ${chapterTitle}` : `\\u00A0`}\n </Text>\n {!hasOnlyOnePage && (\n <HStack>\n <Text fontSize=\"xs\">\n {beginAndEndAreDifferent\n ? `${leftPageIndex + 1} - ${rightPageIndex + 1} of ${totalApproximatePages}`\n : `${leftPageIndex + 1} of ${totalApproximatePages}`}\n </Text>\n {!!pagination?.hasChapters && (\n <>\n <Text>-</Text>\n <Text fontSize=\"xs\">\n ({(pagination?.beginAbsolutePageIndex ?? 0) + 1})\n </Text>\n </>\n )}\n </HStack>\n )}\n </Stack>\n )\n}\n","import { Presence, type PresenceProps } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\n\nexport const QuickBar = memo(\n ({\n children,\n position,\n ...rest\n }: { position: \"top\" | \"bottom\" } & PresenceProps) => {\n return (\n <Presence\n display=\"flex\"\n flexDirection=\"row\"\n width=\"100%\"\n position=\"absolute\"\n {...(position === \"bottom\" ? { bottom: 0 } : { top: 0 })}\n animationName={\n position === \"bottom\"\n ? {\n _open: \"slide-from-bottom, fade-in\",\n _closed: \"slide-to-bottom, fade-out\",\n }\n : {\n _open: \"slide-from-top, fade-in\",\n _closed: \"slide-to-top, fade-out\",\n }\n }\n animationDuration=\"moderate\"\n bgColor=\"bg.panel\"\n alignItems=\"center\"\n justifyContent=\"center\"\n shadow=\"md\"\n p={4}\n {...rest}\n >\n {children}\n </Presence>\n )\n },\n)\n","import RcSlider from \"rc-slider\"\nimport { type ComponentProps, memo } from \"react\"\nimport \"rc-slider/assets/index.css\"\nimport { Box, chakra } from \"@chakra-ui/react\"\n\nconst ChakraRcSlider = chakra(RcSlider)\n\nexport const ThemedSlider = memo((props: ComponentProps<typeof RcSlider>) => {\n return (\n <Box\n display=\"contents\"\n css={{\n \"--bg\": \"colors.bg\",\n \"--bg-emphasized\": \"colors.bg.emphasized\",\n \"--color-solid\": \"colors.colorPalette.solid\",\n }}\n >\n <ChakraRcSlider\n keyboard={false}\n style={{\n padding: 0,\n }}\n css={{\n \"& > .rc-slider-handle:focus-visible\": {\n boxShadow: \"0 0 0 2px var(--color-solid) !important\",\n },\n \"& > .rc-slider-handle:active\": {\n boxShadow: \"0 0 5px var(--color-solid) !important\",\n },\n \"& > .rc-slider-handle.rc-slider-handle-dragging\": {\n boxShadow: \"0 0 0 3px var(--color-solid) !important\",\n },\n }}\n styles={{\n rail: {\n height: \"8px\",\n top: \"50%\",\n transform: \"translateY(-50%)\",\n backgroundColor: \"var(--bg-emphasized)\",\n },\n track: {\n height: \"8px\",\n top: \"50%\",\n transform: \"translateY(-50%)\",\n backgroundColor: \"var(--color-solid)\",\n },\n handle: {\n width: \"24px\",\n height: \"24px\",\n top: \"50%\",\n borderColor: \"var(--color-solid)\",\n transform: `translate(${props.reverse ? \"50%\" : \"-50%\"}, -50%)`,\n backgroundColor: \"var(--bg)\",\n marginTop: \"0px\",\n },\n }}\n {...props}\n />\n </Box>\n )\n})\n","import { type ComponentProps, useCallback, useEffect } from \"react\"\nimport { useObserve, useSignal, useSubscribe } from \"reactjrx\"\nimport { useReader } from \"../../context/useReader\"\nimport { usePagination } from \"../../pagination/usePagination\"\nimport { useNavigationContext } from \"../useNavigationContext\"\nimport { ThemedSlider } from \"./ThemedSlider\"\n\nconst useSliderValues = () => {\n const pagination = usePagination()\n const isUsingSpread = pagination?.isUsingSpread\n const { beginPageIndex: currentRealPage, totalApproximatePages = 0 } =\n useNavigationContext()\n const currentPage = isUsingSpread\n ? Math.floor((currentRealPage || 0) / 2)\n : currentRealPage\n const [value, valueSignal] = useSignal({\n default: currentPage || 0,\n })\n const min = 0\n const max = Math.max(\n 0,\n isUsingSpread\n ? Math.floor((totalApproximatePages - 1) / 2)\n : totalApproximatePages - 1,\n )\n\n useEffect(() => {\n valueSignal.setValue(currentPage || 0)\n }, [currentPage, valueSignal])\n\n return {\n value,\n valueSignal,\n min,\n max,\n }\n}\n\nexport const Scrubber = () => {\n const reader = useReader()\n const pagination = usePagination()\n const { manifest } = useObserve(() => reader?.context.state$, []) ?? {}\n const reverse = manifest?.readingDirection === \"rtl\"\n const isUsingSpread = pagination?.isUsingSpread\n const { totalApproximatePages = 0, isBeginWithinChapter } =\n useNavigationContext()\n const step = 1\n const isScrubberWithinChapter = isBeginWithinChapter\n const { value, valueSignal, min, max } = useSliderValues()\n\n const onChange: NonNullable<ComponentProps<typeof ThemedSlider>[\"onChange\"]> =\n useCallback(\n (values) => {\n const [value = 0] = Array.isArray(values) ? values : [values]\n\n valueSignal.setValue(value)\n\n const pageIndex = isUsingSpread\n ? Math.floor(value) * 2\n : Math.floor(value)\n\n if (!isScrubberWithinChapter) {\n reader?.navigation.goToAbsolutePageIndex({\n absolutePageIndex: pageIndex,\n animation: false,\n })\n } else {\n reader?.navigation.goToPageOfSpineItem({\n pageIndex,\n spineItemId: reader.pagination.getState().beginSpineItemIndex ?? 0,\n animation: false,\n })\n }\n },\n [reader, isUsingSpread, valueSignal, isScrubberWithinChapter],\n )\n\n /**\n * @note\n * Scrubber can navigate fast and without lock we may end up with\n * slowness due to the reader\n * paginating and loading items in between.\n * This is good practice (but not required) to throttle it.\n */\n useSubscribe(\n () =>\n reader?.navigation.throttleLock({\n duration: 100,\n trigger: valueSignal.subject,\n }),\n [reader, valueSignal],\n )\n\n // const marks =\n // max > 1\n // ? Array.from({ length: max + 1 }, (_, i) => i).reduce(\n // (acc: number[], val) => [...acc, val],\n // [],\n // )\n // : []\n\n if (\n totalApproximatePages === 1 ||\n (isUsingSpread && totalApproximatePages === 2)\n ) {\n return null\n }\n\n // @tmp not available yet in chakra\n // if (reverse) return null\n\n return (\n <ThemedSlider\n value={[value]}\n max={max}\n min={min}\n reverse={reverse}\n step={step}\n onChange={onChange}\n />\n )\n // return (\n // <Slider\n // value={[value]}\n // max={max}\n // min={min}\n // marks={marks}\n // onChange={e => {\n // debugger\n // }}\n // onValueChange={onChange}\n // // reverse={reverse}\n // orientation=\"horizontal\"\n // step={step}\n // />\n // )\n}\n","import { Box, Collapsible, HStack, IconButton, Stack } from \"@chakra-ui/react\"\nimport { memo, useState } from \"react\"\nimport { LuChevronDown, LuSearch } from \"react-icons/lu\"\nimport { LuTableOfContents } from \"react-icons/lu\"\nimport { LuCircleHelp } from \"react-icons/lu\"\nimport {\n RxDoubleArrowDown,\n RxDoubleArrowLeft,\n RxDoubleArrowRight,\n RxDoubleArrowUp,\n} from \"react-icons/rx\"\nimport { useObserve } from \"reactjrx\"\nimport { hasSearchEnhancer, useReader } from \"../../context/useReader\"\nimport { PaginationInfoSection } from \"./PaginationInfoSection\"\nimport { QuickBar } from \"./QuickBar\"\nimport { Scrubber } from \"./Scrubber\"\n\nexport const BottomBar = memo(\n ({\n open,\n onTableOfContentsClick,\n onHelpClick,\n onSearchClick,\n }: {\n open: boolean\n onTableOfContentsClick: () => void\n onHelpClick: () => void\n onSearchClick: () => void\n }) => {\n const reader = useReader()\n const navigation = useObserve(() => reader?.navigation.state$, [reader])\n const settings = useObserve(() => reader?.settings.values$, [reader])\n const isVerticalDirection =\n settings?.computedPageTurnDirection === \"vertical\"\n const [isExtraOpen, setIsExtraOpen] = useState(true)\n\n return (\n <QuickBar\n present={open}\n position=\"bottom\"\n // height={130}\n >\n <Stack\n // border=\"1px solid red\"\n flex={1}\n >\n <HStack flex={1} alignItems=\"center\" justifyContent=\"center\">\n <IconButton\n aria-label=\"left\"\n size=\"lg\"\n variant=\"ghost\"\n flexShrink={0}\n onClick={() => reader?.navigation.goToLeftOrTopSpineItem()}\n disabled={\n !navigation?.canGoLeftSpineItem &&\n !navigation?.canGoTopSpineItem\n }\n >\n {isVerticalDirection ? (\n <RxDoubleArrowUp />\n ) : (\n <RxDoubleArrowLeft />\n )}\n </IconButton>\n <Stack\n flex={1}\n maxW={400}\n gap={2}\n alignItems=\"center\"\n overflow=\"visible\"\n px={4}\n >\n <PaginationInfoSection />\n <Box height={5} maxW={300} width=\"100%\" overflow=\"visible\">\n <Scrubber />\n </Box>\n </Stack>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n disabled={\n !navigation?.canGoRightSpineItem &&\n !navigation?.canGoBottomSpineItem\n }\n onClick={() => {\n reader?.navigation.goToRightOrBottomSpineItem()\n }}\n >\n {isVerticalDirection ? (\n <RxDoubleArrowDown />\n ) : (\n <RxDoubleArrowRight />\n )}\n </IconButton>\n </HStack>\n <HStack\n alignItems=\"center\"\n justifyContent=\"center\"\n // border=\"1px solid blue\"\n >\n <Collapsible.Root\n open={isExtraOpen}\n flex={1}\n onOpenChange={({ open }) => {\n setIsExtraOpen(open)\n }}\n >\n <Collapsible.Trigger\n paddingY=\"3\"\n // border=\"1px solid green\"\n width=\"100%\"\n display=\"flex\"\n justifyContent=\"center\"\n >\n <LuChevronDown\n style={{\n transform: isExtraOpen ? \"rotate(0deg)\" : \"rotate(180deg)\",\n }}\n />\n </Collapsible.Trigger>\n <Collapsible.Content\n display=\"flex\"\n justifyContent=\"center\"\n gap={2}\n >\n <IconButton\n aria-label=\"Help\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={onHelpClick}\n >\n <LuCircleHelp />\n </IconButton>\n <IconButton\n aria-label=\"Table of contents\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={onTableOfContentsClick}\n >\n <LuTableOfContents />\n </IconButton>\n {hasSearchEnhancer(reader) && (\n <IconButton\n aria-label=\"Search\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={onSearchClick}\n >\n <LuSearch />\n </IconButton>\n )}\n </Collapsible.Content>\n </Collapsible.Root>\n </HStack>\n </Stack>\n </QuickBar>\n )\n },\n)\n","import { useEffect } from \"react\"\n\nimport { useCallback } from \"react\"\n\nimport { useState } from \"react\"\n\nexport const useFullscreen = () => {\n const [isFullscreen, setIsFullscreen] = useState(false)\n\n const onToggleFullscreenClick = useCallback(() => {\n if (document.fullscreenElement) {\n return document\n .exitFullscreen()\n .catch(console.error)\n .then(() => {\n setIsFullscreen(false)\n })\n }\n\n return document.documentElement\n .requestFullscreen({ navigationUI: \"hide\" })\n .catch(console.error)\n .then(() => {\n setIsFullscreen(true)\n })\n }, [])\n\n useEffect(() => {\n function fullscreenchangeHandler() {\n setIsFullscreen(!!document.fullscreenElement)\n }\n\n document.addEventListener(\"fullscreenchange\", fullscreenchangeHandler)\n\n return () => {\n document.removeEventListener(\"fullscreenchange\", fullscreenchangeHandler)\n }\n }, [])\n\n return {\n isFullscreen,\n onToggleFullscreenClick,\n }\n}\n","import { HStack, IconButton, Stack, Text } from \"@chakra-ui/react\"\nimport { IoIosArrowBack, IoMdMore } from \"react-icons/io\"\nimport { MdFullscreen, MdFullscreenExit } from \"react-icons/md\"\nimport { useObserve } from \"reactjrx\"\nimport { useFullscreen } from \"../../common/useFullscreen\"\nimport { useReader } from \"../../context/useReader\"\nimport { QuickBar } from \"./QuickBar\"\n\nexport const TopBar = ({\n open,\n onBackClick,\n onMoreClick,\n}: {\n open: boolean\n onBackClick: () => void\n onMoreClick: () => void\n}) => {\n const reader = useReader()\n const manifest = useObserve(() => reader?.context.manifest$, [reader])\n const { isFullscreen, onToggleFullscreenClick } = useFullscreen()\n\n return (\n <QuickBar\n present={open}\n position=\"top\"\n height=\"80px\"\n justifyContent=\"space-between\"\n >\n <IconButton\n aria-label=\"left\"\n size=\"lg\"\n variant=\"ghost\"\n flexShrink={0}\n onClick={onBackClick}\n >\n <IoIosArrowBack />\n </IconButton>\n <Stack\n flex={1}\n maxW={600}\n gap={1}\n alignItems=\"center\"\n overflow=\"auto\"\n px={4}\n >\n <Text truncate maxWidth=\"100%\">\n {manifest?.title}\n </Text>\n </Stack>\n <HStack>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n onClick={onMoreClick}\n >\n <IoMdMore />\n </IconButton>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n onClick={onToggleFullscreenClick}\n >\n {isFullscreen ? <MdFullscreenExit /> : <MdFullscreen />}\n </IconButton>\n </HStack>\n </QuickBar>\n )\n}\n","import { memo } from \"react\"\nimport { BottomBar } from \"./BottomBar\"\nimport { TopBar } from \"./TopBar\"\nimport { useQuickMenu } from \"./useQuickMenu\"\n\nexport const QuickMenu = memo(\n ({\n onBackClick,\n onMoreClick,\n onTableOfContentsClick,\n onHelpClick,\n onSearchClick,\n }: {\n onBackClick: () => void\n onMoreClick: () => void\n onTableOfContentsClick: () => void\n onHelpClick: () => void\n onSearchClick: () => void\n }) => {\n const [quickMenuOpen] = useQuickMenu()\n\n return (\n <>\n <TopBar\n open={quickMenuOpen}\n onBackClick={onBackClick}\n onMoreClick={onMoreClick}\n />\n <BottomBar\n open={quickMenuOpen}\n onTableOfContentsClick={onTableOfContentsClick}\n onHelpClick={onHelpClick}\n onSearchClick={onSearchClick}\n />\n </>\n )\n },\n)\n","import { Link, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\n\nexport const SearchListItem = memo(\n ({\n contextText = \"\",\n startOffset = 0,\n text,\n cfi = \"#\",\n onClick,\n absolutePageIndex,\n }: {\n pageIndex: number | undefined\n absolutePageIndex?: number\n contextText?: string\n startOffset?: number\n text: string\n cfi?: string\n onClick: (cfi: string) => void\n }) => {\n const charsAroundText = 15\n const before = contextText.substring(\n Math.max(startOffset - charsAroundText, 0),\n Math.max(startOffset, 0),\n )\n const after = contextText.substring(\n Math.min(startOffset + text.length, contextText.length - 1),\n Math.min(\n startOffset + text.length + charsAroundText,\n contextText.length - 1,\n ),\n )\n\n return (\n <Link\n href={cfi}\n style={{ margin: 5, overflow: \"hidden\" }}\n onClick={(e) => {\n e.preventDefault()\n\n onClick(cfi)\n }}\n display=\"flex\"\n flexDirection=\"column\"\n alignItems=\"flex-start\"\n gap={0}\n >\n <Text lineClamp={1} as=\"cite\" style={{ display: \"block\" }}>\n \"{before}\n <b>{text}</b>\n {after}\"\n </Text>\n <Text fontSize=\"sm\" color=\"gray.500\" style={{ textDecoration: \"none\" }}>\n {`Book page: ${absolutePageIndex !== undefined ? absolutePageIndex + 1 : \"unknown (not loaded)\"}`}\n </Text>\n </Link>\n )\n },\n)\n","import { Box, Heading, Input, Stack, Text } from \"@chakra-ui/react\"\nimport type React from \"react\"\nimport { memo, useCallback, useState } from \"react\"\nimport { useObserve } from \"reactjrx\"\nimport { map, startWith } from \"rxjs\"\nimport { hasSearchEnhancer, useReader } from \"../context/useReader\"\nimport { SearchListItem } from \"./SearchListItem\"\n\nexport const SearchDialogContent = memo(\n ({\n onNavigate,\n }: {\n onNavigate: () => void\n }) => {\n const [text, setText] = useState(\"\")\n const reader = useReader()\n const readerWithSearch = hasSearchEnhancer(reader) ? reader : undefined\n\n const onValueChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setText(e.target.value)\n }\n\n const onClick = useCallback(\n (cfi: string) => {\n onNavigate()\n reader?.navigation.goToCfi(cfi)\n },\n [reader, onNavigate],\n )\n\n const search = useObserve(\n () =>\n readerWithSearch?.search.search(text).pipe(\n map((data) => ({ type: `end` as const, data })),\n startWith({ type: `start` as const }),\n ),\n [reader, text],\n )\n const searching = search?.type === \"start\"\n const results = search?.type === \"end\" ? search.data : []\n const consolidatedResults = useObserve(\n () => reader?.pagination.locate(results.slice(0, 100)),\n [results],\n )\n\n return (\n <Stack flex={1} height=\"100%\">\n <Box px={4}>\n <Input\n placeholder=\"Type something...\"\n value={text}\n onChange={onValueChange}\n borderRadius={0}\n />\n </Box>\n <Box\n px={4}\n pb={4}\n mt={2}\n flex={1}\n style={{ overflow: \"hidden\", overflowY: \"auto\" }}\n >\n {searching && <Text>Searching ...</Text>}\n {!searching && results.length === 0 && <p>There are no results</p>}\n {!searching && results.length >= 0 && (\n <Stack>\n <Heading as=\"h2\" size=\"md\">\n {results.length} result(s)\n </Heading>\n <Stack gap={0}>\n {consolidatedResults?.map((result, j) => {\n return (\n <SearchListItem\n key={j}\n contextText={\n result.meta?.range?.startContainer.parentElement\n ?.textContent ?? \"\"\n }\n pageIndex={result.meta?.itemPageIndex}\n startOffset={result.meta?.range?.startOffset ?? 0}\n text={text}\n cfi={result.cfi}\n onClick={onClick}\n absolutePageIndex={result.meta?.absolutePageIndex}\n />\n )\n })}\n </Stack>\n </Stack>\n )}\n </Box>\n </Stack>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { SearchDialogContent } from \"./SearchDialogContent\"\n\nexport const SearchDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent height=\"100%\">\n <DialogHeader>\n <DialogTitle>Search</DialogTitle>\n </DialogHeader>\n <DialogBody flex={1}>\n <SearchDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Link, Stack, Text } from \"@chakra-ui/react\"\n\nimport { List } from \"@chakra-ui/react\"\nimport React, { memo } from \"react\"\nimport { LuCircleCheck } from \"react-icons/lu\"\nimport { useObserve } from \"reactjrx\"\nimport { useReader } from \"../context/useReader\"\nimport { usePagination } from \"../pagination/usePagination\"\n\nexport const TableOfContentsDialogContent = memo(\n ({\n onNavigate,\n }: {\n onNavigate: () => void\n }) => {\n const reader = useReader()\n const { manifest, assumedRenditionLayout } =\n useObserve(() => reader?.context.state$, [reader]) ?? {}\n const { nav } = manifest ?? {}\n const pagination = usePagination()\n const toc = nav?.toc || []\n const { beginSpineItemIndex, beginPageIndexInSpineItem } = pagination ?? {}\n const currentSpineItemOrChapterPageIndex =\n (assumedRenditionLayout === \"reflowable\"\n ? beginPageIndexInSpineItem\n : beginSpineItemIndex) || 0\n\n console.log({ assumedRenditionLayout, currentSpineItemOrChapterPageIndex })\n\n let currentSubChapter = pagination?.beginChapterInfo\n\n while (currentSubChapter?.subChapter) {\n currentSubChapter = currentSubChapter?.subChapter\n }\n\n const buildTocForItem = (\n tocItem: (typeof toc)[number],\n index: number,\n lvl: number,\n ) => (\n <React.Fragment key={index}>\n <List.Item\n pl={4 * (lvl + 1)}\n style={{\n display: \"flex\",\n alignItems: \"center\",\n }}\n >\n <Link\n onClick={() => {\n onNavigate()\n\n reader?.navigation.goToUrl(tocItem.href)\n }}\n href=\"#\"\n >\n {currentSubChapter?.path === tocItem.path && (\n <List.Indicator asChild>\n <LuCircleCheck />\n </List.Indicator>\n )}\n {currentSubChapter?.path !== tocItem.path && (\n <List.Indicator asChild visibility=\"hidden\">\n <LuCircleCheck />\n </List.Indicator>\n )}\n <Stack gap={0}>\n <Text fontSize=\"md\">{tocItem.title || tocItem.path}</Text>\n {currentSubChapter?.path === tocItem.path && (\n <Text\n fontStyle=\"italic\"\n fontWeight=\"bold\"\n fontSize=\"sm\"\n >{`Currently on page ${\n currentSpineItemOrChapterPageIndex + 1\n }`}</Text>\n )}\n </Stack>\n </Link>\n </List.Item>\n {tocItem.contents.length > 0 && (\n <List.Root as=\"div\" gap={2}>\n {tocItem.contents.map((tocItem, index) =>\n buildTocForItem(tocItem, index, lvl + 1),\n )}\n </List.Root>\n )}\n </React.Fragment>\n )\n\n return (\n <List.Root gap={3} overflowY=\"auto\" py={4} flex={1}>\n {nav?.toc.map((tocItem, index) => buildTocForItem(tocItem, index, 0))}\n </List.Root>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { TableOfContentsDialogContent } from \"./TableOfContentsDialogContent\"\n\nexport const TableOfContentsDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Table of Contents</DialogTitle>\n </DialogHeader>\n <DialogBody overflowY=\"auto\" flex={1}>\n <TableOfContentsDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Presence } from \"@chakra-ui/react\"\nimport { useState } from \"react\"\nimport { HelpDialog } from \"./help/HelpDialog\"\nimport { FloatingProgress } from \"./navigation/FloatingProgress\"\nimport { FloatingTime } from \"./navigation/FloatingTime\"\nimport { QuickMenu } from \"./navigation/QuickMenu/QuickMenu\"\nimport { useQuickMenu } from \"./navigation/QuickMenu/useQuickMenu\"\nimport { SearchDialog } from \"./search/SearchDialog\"\nimport { TableOfContentsDialog } from \"./toc/TableOfContentsDialog\"\n\nexport const ReactReader = ({\n enableFloatingTime = true,\n enableFloatingProgress = true,\n onBackClick,\n onMoreClick,\n}: {\n enableFloatingTime?: boolean\n enableFloatingProgress?: boolean\n onBackClick: () => void\n onMoreClick: () => void\n}) => {\n const [isTableOfContentsOpen, setIsTableOfContentsOpen] = useState(false)\n const [isHelpOpen, setIsHelpOpen] = useState(false)\n const [isSearchOpen, setIsSearchOpen] = useState(false)\n const [quickMenuOpen, setQuickMenuOpen] = useQuickMenu()\n\n return (\n <>\n {enableFloatingProgress && (\n <Presence\n present={!quickMenuOpen}\n animationName={{ _open: \"fade-in\", _closed: \"fade-out\" }}\n animationDuration=\"moderate\"\n >\n <FloatingProgress />\n </Presence>\n )}\n <QuickMenu\n onBackClick={onBackClick}\n onMoreClick={onMoreClick}\n onTableOfContentsClick={() => setIsTableOfContentsOpen(true)}\n onHelpClick={() => setIsHelpOpen(true)}\n onSearchClick={() => setIsSearchOpen(true)}\n />\n <HelpDialog open={isHelpOpen} setOpen={setIsHelpOpen} />\n <TableOfContentsDialog\n open={isTableOfContentsOpen}\n setOpen={setIsTableOfContentsOpen}\n onNavigate={() => {\n setIsTableOfContentsOpen(false)\n setQuickMenuOpen(false)\n }}\n />\n <SearchDialog\n open={isSearchOpen}\n setOpen={setIsSearchOpen}\n onNavigate={() => {\n setIsSearchOpen(false)\n setQuickMenuOpen(false)\n }}\n />\n <Presence\n present={enableFloatingTime || quickMenuOpen}\n animationName={{ _open: \"fade-in\", _closed: \"fade-out\" }}\n animationDuration=\"slow\"\n overflow=\"hidden\"\n >\n <FloatingTime />\n </Presence>\n </>\n )\n}\n"],"names":["ReaderContext","createContext","signal","ReactReaderProvider","memo","children","reader","quickMenuOpen","onQuickMenuOpenChange","quickMenuSignal","useSignal","onQuickMenuOpenChangeLiveRef","useLiveRef","value","useMemo","useEffect","useSubscribe","tap","jsx","CloseButton","React","props","ref","ChakraIconButton","LuX","DialogContent","portalled","portalRef","backdrop","rest","Portal","ChakraDialog","DialogCloseTrigger","DialogRoot","DialogFooter","DialogHeader","DialogBody","DialogTitle","DialogActionTrigger","HelpDialog","open","setOpen","e","jsxs","Heading","HStack","Kbd","LuArrowBigRight","Text","LuArrowBigLeft","name","version","Button","useReader","useContext","hasSearchEnhancer","usePagination","useObserve","combineLatest","map","state","context","isOnlyImages","_a","item","NEVER","FloatingProgress","pagination","roundedProgress","displayableProgress","Box","useTime","time","setTime","useState","interval","TimeIndicator","useQuickMenu","useSignalValue","FloatingTime","ToggleTip","showArrow","content","ChakraPopover","InfoTip","IconButton","HiOutlineInformationCircle","ProgressBar","ChakraProgress","React__namespace","info","ProgressRoot","ProgressValueText","useNavigationContext","hasOnlyOnePage","isBeginWithinChapter","isEndWithinChapter","beginPageIndex","endPageIndex","leftPageIndex","rightPageIndex","a","b","beginAndEndAreDifferent","totalApproximatePages","PaginationInfoSection","progress","buildTitleChain","chapterInfo","chapterTitle","Stack","Fragment","QuickBar","position","Presence","ChakraRcSlider","chakra","RcSlider","ThemedSlider","useSliderValues","isUsingSpread","currentRealPage","currentPage","valueSignal","min","max","Scrubber","manifest","reverse","step","isScrubberWithinChapter","onChange","useCallback","values","pageIndex","BottomBar","onTableOfContentsClick","onHelpClick","onSearchClick","navigation","settings","isVerticalDirection","isExtraOpen","setIsExtraOpen","RxDoubleArrowUp","RxDoubleArrowLeft","RxDoubleArrowDown","RxDoubleArrowRight","Collapsible","LuChevronDown","LuCircleHelp","LuTableOfContents","LuSearch","useFullscreen","isFullscreen","setIsFullscreen","onToggleFullscreenClick","fullscreenchangeHandler","TopBar","onBackClick","onMoreClick","IoIosArrowBack","IoMdMore","MdFullscreenExit","MdFullscreen","QuickMenu","SearchListItem","contextText","startOffset","text","cfi","onClick","absolutePageIndex","before","after","Link","SearchDialogContent","onNavigate","setText","readerWithSearch","onValueChange","search","data","startWith","searching","results","consolidatedResults","Input","result","j","_c","_b","_d","_f","_e","_g","SearchDialog","TableOfContentsDialogContent","assumedRenditionLayout","nav","beginSpineItemIndex","beginPageIndexInSpineItem","currentSpineItemOrChapterPageIndex","currentSubChapter","buildTocForItem","tocItem","index","lvl","List","LuCircleCheck","TableOfContentsDialog","ReactReader","enableFloatingTime","enableFloatingProgress","isTableOfContentsOpen","setIsTableOfContentsOpen","isHelpOpen","setIsHelpOpen","isSearchOpen","setIsSearchOpen","setQuickMenuOpen"],"mappings":"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"}
1
+ {"version":3,"file":"index.umd.cjs","sources":["../src/context/context.ts","../src/context/ReactReaderProvider.tsx","../src/components/ui/close-button.tsx","../src/components/ui/dialog.tsx","../src/context/useReader.ts","../src/annotations/AnnotationsDialogContent.tsx","../src/annotations/AnnotationsDialog.tsx","../src/bookmarks/BookmarksDialogContent.tsx","../src/bookmarks/BookmarksDialog.tsx","../src/help/HelpDialog.tsx","../src/pagination/usePagination.ts","../src/navigation/FloatingProgress.tsx","../src/quickmenu/TimeIndicator.tsx","../src/quickmenu/useQuickMenu.ts","../src/navigation/FloatingTime.tsx","../src/components/ui/toggle-tip.tsx","../src/components/ui/progress.tsx","../src/navigation/useNavigationContext.ts","../src/quickmenu/PaginationInfoSection.tsx","../src/quickmenu/QuickBar.tsx","../src/quickmenu/ThemedSlider.tsx","../src/quickmenu/Scrubber.tsx","../src/quickmenu/BottomBar.tsx","../src/common/useFullscreen.ts","../src/quickmenu/TopBar.tsx","../src/quickmenu/QuickMenu.tsx","../src/search/SearchListItem.tsx","../src/search/SearchDialogContent.tsx","../src/search/SearchDialog.tsx","../src/toc/TableOfContentsDialogContent.tsx","../src/toc/TableOfContentsDialog.tsx","../src/ReactReader.tsx"],"sourcesContent":["import type { Reader } from \"@prose-reader/core\"\nimport { type Context, createContext } from \"react\"\nimport { type Signal, signal } from \"reactjrx\"\n\ntype ContextType = {\n reader: Reader | undefined\n quickMenuSignal: Signal<boolean, boolean, undefined>\n}\n\nexport const ReaderContext: Context<ContextType> = createContext<ContextType>({\n reader: undefined,\n quickMenuSignal: signal({ default: false }),\n})\n","import type { Reader } from \"@prose-reader/core\"\nimport { memo, useEffect, useMemo } from \"react\"\nimport { useLiveRef, useSignal, useSubscribe } from \"reactjrx\"\nimport { tap } from \"rxjs\"\nimport { ReaderContext } from \"./context\"\n\nexport const ReactReaderProvider = memo(\n ({\n children,\n reader,\n quickMenuOpen,\n onQuickMenuOpenChange,\n }: {\n children?: React.ReactNode\n reader: Reader | undefined\n quickMenuOpen: boolean\n onQuickMenuOpenChange: (open: boolean) => void\n }) => {\n const [, quickMenuSignal] = useSignal({\n default: quickMenuOpen,\n })\n const onQuickMenuOpenChangeLiveRef = useLiveRef(onQuickMenuOpenChange)\n\n const value = useMemo(\n () => ({\n quickMenuSignal,\n reader,\n }),\n [quickMenuSignal, reader],\n )\n\n useEffect(() => {\n quickMenuSignal.setValue(quickMenuOpen)\n }, [quickMenuOpen, quickMenuSignal])\n\n useSubscribe(\n () =>\n quickMenuSignal.subject.pipe(tap(onQuickMenuOpenChangeLiveRef.current)),\n [quickMenuSignal, onQuickMenuOpenChangeLiveRef],\n )\n\n return (\n <ReaderContext.Provider value={value}>{children}</ReaderContext.Provider>\n )\n },\n)\n","import type { ButtonProps } from \"@chakra-ui/react\"\nimport { IconButton as ChakraIconButton } from \"@chakra-ui/react\"\nimport * as React from \"react\"\nimport { LuX } from \"react-icons/lu\"\n\nexport type CloseButtonProps = ButtonProps\n\nexport const CloseButton = React.forwardRef<\n HTMLButtonElement,\n CloseButtonProps\n>(function CloseButton(props, ref) {\n return (\n <ChakraIconButton variant=\"ghost\" aria-label=\"Close\" ref={ref} {...props}>\n {props.children ?? <LuX />}\n </ChakraIconButton>\n )\n})\n","import { Dialog as ChakraDialog, Portal } from \"@chakra-ui/react\"\nimport { CloseButton } from \"./close-button\"\nimport * as React from \"react\"\n\ninterface DialogContentProps extends ChakraDialog.ContentProps {\n portalled?: boolean\n portalRef?: React.RefObject<HTMLElement>\n backdrop?: boolean\n}\n\nexport const DialogContent = React.forwardRef<\n HTMLDivElement,\n DialogContentProps\n>(function DialogContent(props, ref) {\n const {\n children,\n portalled = true,\n portalRef,\n backdrop = true,\n ...rest\n } = props\n\n return (\n <Portal disabled={!portalled} container={portalRef}>\n {backdrop && <ChakraDialog.Backdrop />}\n <ChakraDialog.Positioner>\n <ChakraDialog.Content ref={ref} {...rest} asChild={false}>\n {children}\n </ChakraDialog.Content>\n </ChakraDialog.Positioner>\n </Portal>\n )\n})\n\nexport const DialogCloseTrigger = React.forwardRef<\n HTMLButtonElement,\n ChakraDialog.CloseTriggerProps\n>(function DialogCloseTrigger(props, ref) {\n return (\n <ChakraDialog.CloseTrigger\n position=\"absolute\"\n top=\"2\"\n insetEnd=\"2\"\n {...props}\n asChild\n >\n <CloseButton size=\"sm\" ref={ref}>\n {props.children}\n </CloseButton>\n </ChakraDialog.CloseTrigger>\n )\n})\n\nexport const DialogRoot = ChakraDialog.Root\nexport const DialogFooter = ChakraDialog.Footer\nexport const DialogHeader = ChakraDialog.Header\nexport const DialogBody = ChakraDialog.Body\nexport const DialogBackdrop = ChakraDialog.Backdrop\nexport const DialogTitle = ChakraDialog.Title\nexport const DialogDescription = ChakraDialog.Description\nexport const DialogTrigger = ChakraDialog.Trigger\nexport const DialogActionTrigger = ChakraDialog.ActionTrigger\n","import type { Reader } from \"@prose-reader/core\"\nimport type { AnnotationsEnhancerAPI } from \"@prose-reader/enhancer-annotations\"\nimport type { BookmarksEnhancerAPI } from \"@prose-reader/enhancer-bookmarks\"\nimport type { SearchEnhancerAPI } from \"@prose-reader/enhancer-search\"\nimport { useContext } from \"react\"\nimport { ReaderContext } from \"./context\"\n\nexport const useReader = (): Reader | undefined => {\n const { reader } = useContext(ReaderContext)\n\n return reader\n}\n\nexport const hasSearchEnhancer = (\n reader?: Reader,\n): reader is Reader & SearchEnhancerAPI => {\n return !!reader && \"__PROSE_READER_ENHANCER_SEARCH\" in reader\n}\n\nexport const hasBookmarksEnhancer = (\n reader?: Reader,\n): reader is Reader & BookmarksEnhancerAPI => {\n return !!reader && \"__PROSE_READER_ENHANCER_BOOKMARKS\" in reader\n}\n\nexport const hasAnnotationsEnhancer = (\n reader?: Reader,\n): reader is Reader & AnnotationsEnhancerAPI => {\n return !!reader && \"__PROSE_READER_ENHANCER_ANNOTATIONS\" in reader\n}\n","import { Link, List, Stack, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport { LuNotebookPen } from \"react-icons/lu\"\nimport { useObserve } from \"reactjrx\"\nimport { switchMap } from \"rxjs\"\nimport { hasAnnotationsEnhancer, useReader } from \"../context/useReader\"\n\nexport const AnnotationsDialogContent = memo(\n ({ onNavigate }: { onNavigate: () => void }) => {\n const reader = useReader()\n const readerWithAnnotations = hasAnnotationsEnhancer(reader)\n ? reader\n : undefined\n\n const consolidatedHighlights = useObserve(\n () =>\n readerWithAnnotations?.annotations.highlights$.pipe(\n switchMap((highlights) =>\n readerWithAnnotations.pagination.locate(highlights),\n ),\n ),\n [readerWithAnnotations],\n )\n\n const mapItemToListEntry = (\n item: NonNullable<typeof consolidatedHighlights>[number],\n index: number,\n ) => (\n <List.Item key={index}>\n <Link\n href=\"#\"\n onClick={() => {\n onNavigate()\n\n reader?.navigation.goToCfi(item.cfi ?? \"\")\n }}\n >\n {(item.contents ?? [])[0] ? (\n <List.Indicator asChild>\n <LuNotebookPen />\n </List.Indicator>\n ) : (\n <List.Indicator asChild visibility=\"hidden\">\n <LuNotebookPen />\n </List.Indicator>\n )}\n <Stack gap={0}>\n <Text lineClamp={2} fontSize=\"md\">\n {item.selectionAsText ? (\n (item.selectionAsText ?? \"\")\n ) : (\n <i>\n <b>unknown (not loaded)</b>\n </i>\n )}\n </Text>\n <Text\n fontStyle=\"italic\"\n fontWeight=\"bold\"\n fontSize=\"sm\"\n >{`Book page: ${\n item.meta?.absolutePageIndex !== undefined\n ? item.meta.absolutePageIndex + 1\n : \"unknown (not loaded)\"\n }`}</Text>\n </Stack>\n </Link>\n </List.Item>\n )\n\n return (\n <List.Root overflowY=\"auto\" gap={3} pt={4} variant=\"plain\">\n {consolidatedHighlights?.map((item, index) =>\n mapItemToListEntry(item, index),\n )}\n </List.Root>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { AnnotationsDialogContent } from \"./AnnotationsDialogContent\"\n\nexport const AnnotationsDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent height=\"100%\">\n <DialogHeader>\n <DialogTitle>Annotations</DialogTitle>\n </DialogHeader>\n <DialogBody flex={1}>\n <AnnotationsDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Button, Link, List, Stack, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport { useObserve } from \"reactjrx\"\nimport { switchMap } from \"rxjs\"\nimport { hasBookmarksEnhancer, useReader } from \"../context/useReader\"\n\nexport const BookmarksDialogContent = memo(\n ({ onNavigate }: { onNavigate: () => void }) => {\n const reader = useReader()\n const readerWithBookmarks = hasBookmarksEnhancer(reader)\n ? reader\n : undefined\n\n const consolidatedBookmarks = useObserve(\n () =>\n readerWithBookmarks?.bookmarks.bookmarks$.pipe(\n switchMap((items) => readerWithBookmarks.pagination.locate(items)),\n ),\n [readerWithBookmarks],\n )\n\n const mapItemToListEntry = (\n item: NonNullable<typeof consolidatedBookmarks>[number],\n index: number,\n ) => (\n <List.Item key={index} justifyContent=\"space-between\" alignItems=\"center\">\n <Link\n href=\"#\"\n onClick={() => {\n onNavigate()\n\n reader?.navigation.goToCfi(item.cfi ?? \"\")\n }}\n >\n <Stack gap={0}>\n <Text fontSize=\"md\">\n {`Book page: ${\n item.meta?.absolutePageIndex !== undefined\n ? item.meta.absolutePageIndex + 1\n : \"unknown\"\n }`}\n </Text>\n <Text\n fontStyle=\"italic\"\n fontWeight=\"bold\"\n fontSize=\"sm\"\n truncate\n lineClamp={2}\n >\n {item.meta?.startNode?.textContent\n ? item.meta?.startNode?.textContent\n : \"...\"}\n </Text>\n </Stack>\n </Link>\n <Button\n colorPalette=\"red\"\n variant=\"solid\"\n size=\"xs\"\n onClick={() => {\n readerWithBookmarks?.bookmarks.delete(item.id)\n }}\n >\n Delete\n </Button>\n </List.Item>\n )\n\n return (\n <List.Root overflowY=\"auto\" gap={3} variant=\"plain\" overflow=\"auto\">\n {consolidatedBookmarks?.map((item, index) =>\n mapItemToListEntry(item, index),\n )}\n </List.Root>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { BookmarksDialogContent } from \"./BookmarksDialogContent\"\n\nexport const BookmarksDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent height=\"100%\">\n <DialogHeader>\n <DialogTitle>Bookmarks</DialogTitle>\n </DialogHeader>\n <DialogBody>\n <BookmarksDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Button, HStack, Heading, Kbd, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport { LuArrowBigLeft, LuArrowBigRight } from \"react-icons/lu\"\nimport { name, version } from \"../../package.json\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\n\nexport const HelpDialog = memo(\n ({\n open,\n setOpen,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Help</DialogTitle>\n </DialogHeader>\n <DialogBody overflowY=\"auto\" flex={1}>\n <Heading mb={2} as=\"h3\" size=\"lg\">\n Shortcuts\n </Heading>\n <HStack mb={1}>\n <Kbd>\n <LuArrowBigRight />\n </Kbd>{\" \"}\n <Text>Navigate to right page</Text>\n </HStack>\n <HStack mb={1}>\n <Kbd>\n <LuArrowBigLeft />\n </Kbd>{\" \"}\n <Text>Navigate to left page</Text>\n </HStack>\n <Heading mb={2} mt={4} as=\"h3\" size=\"lg\">\n About\n </Heading>\n <Text>\n {name} version: {version}\n </Text>\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import type { Reader } from \"@prose-reader/core\"\nimport { useObserve } from \"reactjrx\"\nimport { NEVER, combineLatest, map } from \"rxjs\"\nimport { useReader } from \"../context/useReader\"\n\nexport const usePagination = ():\n | (Reader[\"pagination\"][\"state\"] & { hasChapters: boolean })\n | undefined => {\n const reader = useReader()\n\n return useObserve(\n () =>\n !reader\n ? NEVER\n : combineLatest([reader.pagination.state$, reader.context.state$]).pipe(\n map(([state, context]) => {\n const isOnlyImages = context.manifest?.spineItems.every((item) =>\n item.mediaType?.startsWith(\"image/\"),\n )\n\n return {\n ...state,\n hasChapters: !context.isFullyPrePaginated && !isOnlyImages,\n }\n }),\n ),\n [reader],\n )\n}\n","import { Box, Text } from \"@chakra-ui/react\"\nimport { usePagination } from \"../pagination/usePagination\"\n\nexport const FloatingProgress = () => {\n const pagination = usePagination()\n const roundedProgress = Math.floor(\n (pagination?.percentageEstimateOfBook ?? 0) * 100,\n )\n const displayableProgress = roundedProgress > 0 ? roundedProgress : 1\n\n if (pagination?.percentageEstimateOfBook === undefined) return null\n\n return (\n <Box position=\"absolute\" right={0} bottom={0} p={2} color={\"black\"}>\n <Text fontSize=\"sm\">{displayableProgress} %</Text>\n </Box>\n )\n}\n","import { Text, type TextProps } from \"@chakra-ui/react\"\nimport { useEffect, useState } from \"react\"\n\nexport const useTime = () => {\n const [time, setTime] = useState(new Date())\n\n useEffect(() => {\n const interval = setInterval(() => {\n setTime(new Date())\n }, 1000 * 60)\n\n return () => clearInterval(interval)\n }, [])\n\n return time\n}\n\nexport const TimeIndicator = (props: TextProps) => {\n const time = useTime()\n\n return (\n <Text fontSize=\"xs\" {...props}>\n {time.toLocaleTimeString(navigator.language, {\n hour: \"2-digit\",\n minute: \"2-digit\",\n })}\n </Text>\n )\n}\n","import { useContext } from \"react\"\nimport { useSignalValue } from \"reactjrx\"\nimport { ReaderContext } from \"../context/context\"\n\nexport const useQuickMenu = () => {\n const { quickMenuSignal } = useContext(ReaderContext)\n\n const quickMenu = useSignalValue(quickMenuSignal)\n\n return [quickMenu, quickMenuSignal.setValue, quickMenuSignal] as const\n}\n","import { Box } from \"@chakra-ui/react\"\nimport { TimeIndicator } from \"../quickmenu/TimeIndicator\"\nimport { useQuickMenu } from \"../quickmenu/useQuickMenu\"\n\nexport const FloatingTime = () => {\n const [quickMenuOpen] = useQuickMenu()\n\n return (\n <Box\n position=\"absolute\"\n left={0}\n bottom={0}\n p={2}\n color={quickMenuOpen ? undefined : \"colorPalette.contrast\"}\n >\n <TimeIndicator />\n </Box>\n )\n}\n","import { Popover as ChakraPopover, IconButton, Portal } from \"@chakra-ui/react\"\nimport * as React from \"react\"\nimport { HiOutlineInformationCircle } from \"react-icons/hi\"\n\nexport interface ToggleTipProps extends ChakraPopover.RootProps {\n showArrow?: boolean\n portalled?: boolean\n portalRef?: React.RefObject<HTMLElement>\n content?: React.ReactNode\n}\n\nexport const ToggleTip = React.forwardRef<HTMLDivElement, ToggleTipProps>(\n function ToggleTip(props, ref) {\n const {\n showArrow,\n children,\n portalled = true,\n content,\n portalRef,\n ...rest\n } = props\n\n return (\n <ChakraPopover.Root\n {...rest}\n positioning={{ ...rest.positioning, gutter: 4 }}\n >\n <ChakraPopover.Trigger asChild>{children}</ChakraPopover.Trigger>\n <Portal disabled={!portalled} container={portalRef}>\n <ChakraPopover.Positioner>\n <ChakraPopover.Content\n width=\"auto\"\n px=\"2\"\n py=\"1\"\n textStyle=\"xs\"\n rounded=\"sm\"\n ref={ref}\n >\n {showArrow && (\n <ChakraPopover.Arrow>\n <ChakraPopover.ArrowTip />\n </ChakraPopover.Arrow>\n )}\n {content}\n </ChakraPopover.Content>\n </ChakraPopover.Positioner>\n </Portal>\n </ChakraPopover.Root>\n )\n },\n)\n\nexport const InfoTip = React.forwardRef<\n HTMLDivElement,\n Partial<ToggleTipProps>\n>(function InfoTip(props, ref) {\n const { children, ...rest } = props\n return (\n <ToggleTip content={children} {...rest} ref={ref}>\n <IconButton\n variant=\"ghost\"\n aria-label=\"info\"\n size=\"2xs\"\n colorPalette=\"gray\"\n >\n <HiOutlineInformationCircle />\n </IconButton>\n </ToggleTip>\n )\n})\n","import { Progress as ChakraProgress } from \"@chakra-ui/react\"\nimport { InfoTip } from \"./toggle-tip\"\nimport * as React from \"react\"\n\nexport const ProgressBar = React.forwardRef<\n HTMLDivElement,\n ChakraProgress.TrackProps\n>(function ProgressBar(props, ref) {\n return (\n <ChakraProgress.Track {...props} ref={ref}>\n <ChakraProgress.Range />\n </ChakraProgress.Track>\n )\n})\n\nexport interface ProgressLabelProps extends ChakraProgress.LabelProps {\n info?: React.ReactNode\n}\n\nexport const ProgressLabel = React.forwardRef<\n HTMLDivElement,\n ProgressLabelProps\n>(function ProgressLabel(props, ref) {\n const { children, info, ...rest } = props\n return (\n <ChakraProgress.Label {...rest} ref={ref}>\n {children}\n {info && <InfoTip>{info}</InfoTip>}\n </ChakraProgress.Label>\n )\n})\n\nexport const ProgressRoot = ChakraProgress.Root\nexport const ProgressValueText = ChakraProgress.ValueText\n","import { usePagination } from \"../pagination/usePagination\"\n\nexport const useNavigationContext = () => {\n const pagination = usePagination()\n const hasOnlyOnePage = pagination?.numberOfTotalPages === 1\n\n const isBeginWithinChapter =\n (pagination?.beginNumberOfPagesInSpineItem ?? 0) > 1\n\n const isEndWithinChapter = (pagination?.endNumberOfPagesInSpineItem ?? 0) > 1\n\n const beginPageIndex =\n (pagination?.hasChapters\n ? pagination?.beginPageIndexInSpineItem\n : pagination?.beginAbsolutePageIndex) ?? 0\n const endPageIndex =\n (pagination?.hasChapters\n ? pagination?.endPageIndexInSpineItem\n : pagination?.endAbsolutePageIndex) ?? 0\n\n const [leftPageIndex = 0, rightPageIndex = 0] = [\n beginPageIndex,\n endPageIndex,\n ].sort((a, b) => a - b)\n\n const beginAndEndAreDifferent =\n pagination?.beginPageIndexInSpineItem !==\n pagination?.endPageIndexInSpineItem ||\n pagination?.beginSpineItemIndex !== pagination?.endSpineItemIndex\n\n const totalApproximatePages = pagination?.hasChapters\n ? pagination?.beginNumberOfPagesInSpineItem\n : pagination?.numberOfTotalPages\n\n return {\n hasOnlyOnePage,\n beginPageIndex,\n endPageIndex,\n isBeginWithinChapter,\n isEndWithinChapter,\n beginAndEndAreDifferent,\n totalApproximatePages,\n leftPageIndex,\n rightPageIndex,\n }\n}\n","import { HStack, Stack, Text } from \"@chakra-ui/react\"\nimport {\n ProgressBar,\n ProgressRoot,\n ProgressValueText,\n} from \"../components/ui/progress\"\nimport { useNavigationContext } from \"../navigation/useNavigationContext\"\nimport { usePagination } from \"../pagination/usePagination\"\n\nexport const PaginationInfoSection = () => {\n const pagination = usePagination()\n const {\n hasOnlyOnePage,\n leftPageIndex,\n rightPageIndex,\n totalApproximatePages,\n beginAndEndAreDifferent,\n } = useNavigationContext()\n const progress = Math.round((pagination?.percentageEstimateOfBook ?? 0) * 100)\n\n const buildTitleChain = (\n chapterInfo: NonNullable<typeof pagination>[\"beginChapterInfo\"],\n ): string => {\n if (chapterInfo?.subChapter) {\n return `${chapterInfo.title} / ${buildTitleChain(chapterInfo.subChapter)}`\n }\n return chapterInfo?.title || \"\"\n }\n\n const chapterTitle = buildTitleChain(pagination?.beginChapterInfo)\n\n return (\n <Stack alignItems=\"center\" gap={1} maxW=\"100%\" overflow=\"auto\">\n <ProgressRoot value={progress} size=\"xs\" width={150}>\n <HStack justifyContent=\"space-between\">\n <ProgressBar width={110} />\n <ProgressValueText>{`${progress}%`}</ProgressValueText>\n </HStack>\n </ProgressRoot>\n <Text truncate maxWidth=\"100%\" fontSize=\"sm\" mt={1}>\n {chapterTitle ? `Chapter: ${chapterTitle}` : `\\u00A0`}\n </Text>\n {!hasOnlyOnePage && (\n <HStack>\n <Text fontSize=\"xs\">\n {beginAndEndAreDifferent\n ? `${leftPageIndex + 1} - ${rightPageIndex + 1} of ${totalApproximatePages}`\n : `${leftPageIndex + 1} of ${totalApproximatePages}`}\n </Text>\n {!!pagination?.hasChapters && (\n <>\n <Text>-</Text>\n <Text fontSize=\"xs\">\n ({(pagination?.beginAbsolutePageIndex ?? 0) + 1})\n </Text>\n </>\n )}\n </HStack>\n )}\n </Stack>\n )\n}\n","import { Presence, type PresenceProps } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\n\nexport const QuickBar = memo(\n ({\n children,\n position,\n ...rest\n }: { position: \"top\" | \"bottom\" } & PresenceProps) => {\n return (\n <Presence\n display=\"flex\"\n flexDirection=\"row\"\n width=\"100%\"\n position=\"absolute\"\n {...(position === \"bottom\" ? { bottom: 0 } : { top: 0 })}\n animationName={\n position === \"bottom\"\n ? {\n _open: \"slide-from-bottom, fade-in\",\n _closed: \"slide-to-bottom, fade-out\",\n }\n : {\n _open: \"slide-from-top, fade-in\",\n _closed: \"slide-to-top, fade-out\",\n }\n }\n animationDuration=\"moderate\"\n bgColor=\"bg.panel\"\n alignItems=\"center\"\n justifyContent=\"center\"\n shadow=\"md\"\n p={4}\n {...rest}\n >\n {children}\n </Presence>\n )\n },\n)\n","import RcSlider from \"rc-slider\"\nimport { type ComponentProps, memo } from \"react\"\nimport \"rc-slider/assets/index.css\"\nimport { Box, chakra } from \"@chakra-ui/react\"\n\nconst ChakraRcSlider = chakra(RcSlider)\n\nexport const ThemedSlider = memo((props: ComponentProps<typeof RcSlider>) => {\n return (\n <Box\n display=\"contents\"\n css={{\n \"--bg\": \"colors.bg\",\n \"--bg-emphasized\": \"colors.bg.emphasized\",\n \"--color-solid\": \"colors.colorPalette.solid\",\n }}\n >\n <ChakraRcSlider\n keyboard={false}\n style={{\n padding: 0,\n }}\n css={{\n \"& > .rc-slider-handle:focus-visible\": {\n boxShadow: \"0 0 0 2px var(--color-solid) !important\",\n },\n \"& > .rc-slider-handle:active\": {\n boxShadow: \"0 0 5px var(--color-solid) !important\",\n },\n \"& > .rc-slider-handle.rc-slider-handle-dragging\": {\n boxShadow: \"0 0 0 3px var(--color-solid) !important\",\n },\n }}\n styles={{\n rail: {\n height: \"8px\",\n top: \"50%\",\n transform: \"translateY(-50%)\",\n backgroundColor: \"var(--bg-emphasized)\",\n },\n track: {\n height: \"8px\",\n top: \"50%\",\n transform: \"translateY(-50%)\",\n backgroundColor: \"var(--color-solid)\",\n },\n handle: {\n width: \"24px\",\n height: \"24px\",\n top: \"50%\",\n borderColor: \"var(--color-solid)\",\n transform: `translate(${props.reverse ? \"50%\" : \"-50%\"}, -50%)`,\n backgroundColor: \"var(--bg)\",\n marginTop: \"0px\",\n },\n }}\n {...props}\n />\n </Box>\n )\n})\n","import { type ComponentProps, useCallback, useEffect } from \"react\"\nimport { useObserve, useSignal, useSubscribe } from \"reactjrx\"\nimport { useReader } from \"../context/useReader\"\nimport { useNavigationContext } from \"../navigation/useNavigationContext\"\nimport { usePagination } from \"../pagination/usePagination\"\nimport { ThemedSlider } from \"./ThemedSlider\"\n\nconst useSliderValues = () => {\n const pagination = usePagination()\n const isUsingSpread = pagination?.isUsingSpread\n const { beginPageIndex: currentRealPage, totalApproximatePages = 0 } =\n useNavigationContext()\n const currentPage = isUsingSpread\n ? Math.floor((currentRealPage || 0) / 2)\n : currentRealPage\n const [value, valueSignal] = useSignal({\n default: currentPage || 0,\n })\n const min = 0\n const max = Math.max(\n 0,\n isUsingSpread\n ? Math.floor((totalApproximatePages - 1) / 2)\n : totalApproximatePages - 1,\n )\n\n useEffect(() => {\n valueSignal.setValue(currentPage || 0)\n }, [currentPage, valueSignal])\n\n return {\n value,\n valueSignal,\n min,\n max,\n }\n}\n\nexport const Scrubber = (props: ComponentProps<typeof ThemedSlider>) => {\n const reader = useReader()\n const pagination = usePagination()\n const { manifest } = useObserve(() => reader?.context.state$, []) ?? {}\n const reverse = manifest?.readingDirection === \"rtl\"\n const isUsingSpread = pagination?.isUsingSpread\n const { totalApproximatePages = 0, isBeginWithinChapter } =\n useNavigationContext()\n const step = 1\n const isScrubberWithinChapter = isBeginWithinChapter\n const { value, valueSignal, min, max } = useSliderValues()\n\n const onChange: NonNullable<ComponentProps<typeof ThemedSlider>[\"onChange\"]> =\n useCallback(\n (values) => {\n const [value = 0] = Array.isArray(values) ? values : [values]\n\n valueSignal.setValue(value)\n\n const pageIndex = isUsingSpread\n ? Math.floor(value) * 2\n : Math.floor(value)\n\n if (!isScrubberWithinChapter) {\n reader?.navigation.goToAbsolutePageIndex({\n absolutePageIndex: pageIndex,\n animation: false,\n })\n } else {\n reader?.navigation.goToPageOfSpineItem({\n pageIndex,\n spineItemId: reader.pagination.getState().beginSpineItemIndex ?? 0,\n animation: false,\n })\n }\n },\n [reader, isUsingSpread, valueSignal, isScrubberWithinChapter],\n )\n\n /**\n * @note\n * Scrubber can navigate fast and without lock we may end up with\n * slowness due to the reader\n * paginating and loading items in between.\n * This is good practice (but not required) to throttle it.\n */\n useSubscribe(\n () =>\n reader?.navigation.throttleLock({\n duration: 100,\n trigger: valueSignal.subject,\n }),\n [reader, valueSignal],\n )\n\n // const marks =\n // max > 1\n // ? Array.from({ length: max + 1 }, (_, i) => i).reduce(\n // (acc: number[], val) => [...acc, val],\n // [],\n // )\n // : []\n\n if (\n totalApproximatePages === 1 ||\n (isUsingSpread && totalApproximatePages === 2)\n ) {\n return null\n }\n\n // @tmp not available yet in chakra\n // if (reverse) return null\n\n return (\n <ThemedSlider\n value={[value]}\n max={max}\n min={min}\n reverse={reverse}\n step={step}\n onChange={onChange}\n {...props}\n />\n )\n // return (\n // <Slider\n // value={[value]}\n // max={max}\n // min={min}\n // marks={marks}\n // onChange={e => {\n // debugger\n // }}\n // onValueChange={onChange}\n // // reverse={reverse}\n // orientation=\"horizontal\"\n // step={step}\n // />\n // )\n}\n","import { Collapsible, HStack, IconButton, Stack } from \"@chakra-ui/react\"\nimport { memo, useState } from \"react\"\nimport { BsBookmarks } from \"react-icons/bs\"\nimport { LuChevronDown, LuSearch } from \"react-icons/lu\"\nimport { LuTableOfContents } from \"react-icons/lu\"\nimport { LuCircleHelp, LuNotebookPen } from \"react-icons/lu\"\nimport {\n RxDoubleArrowDown,\n RxDoubleArrowLeft,\n RxDoubleArrowRight,\n RxDoubleArrowUp,\n} from \"react-icons/rx\"\nimport { useObserve } from \"reactjrx\"\nimport {\n hasAnnotationsEnhancer,\n hasBookmarksEnhancer,\n hasSearchEnhancer,\n useReader,\n} from \"../context/useReader\"\nimport { PaginationInfoSection } from \"./PaginationInfoSection\"\nimport { QuickBar } from \"./QuickBar\"\nimport { Scrubber } from \"./Scrubber\"\n\nexport const BottomBar = memo(\n ({\n open,\n onItemClick,\n }: {\n open: boolean\n onItemClick: (\n item: \"annotations\" | \"search\" | \"help\" | \"toc\" | \"bookmarks\",\n ) => void\n }) => {\n const reader = useReader()\n const navigation = useObserve(() => reader?.navigation.state$, [reader])\n const settings = useObserve(() => reader?.settings.values$, [reader])\n const isVerticalDirection =\n settings?.computedPageTurnDirection === \"vertical\"\n const [isExtraOpen, setIsExtraOpen] = useState(true)\n\n return (\n <QuickBar present={open} position=\"bottom\">\n <Stack flex={1} overflow=\"auto\">\n <HStack flex={1} alignItems=\"center\" justifyContent=\"center\">\n <IconButton\n aria-label=\"left\"\n size=\"lg\"\n variant=\"ghost\"\n flexShrink={0}\n onClick={() => reader?.navigation.goToLeftOrTopSpineItem()}\n disabled={\n !navigation?.canGoLeftSpineItem &&\n !navigation?.canGoTopSpineItem\n }\n >\n {isVerticalDirection ? (\n <RxDoubleArrowUp />\n ) : (\n <RxDoubleArrowLeft />\n )}\n </IconButton>\n <Stack\n flex={1}\n maxW={400}\n gap={2}\n alignItems=\"center\"\n overflow=\"auto\"\n px={4}\n >\n <PaginationInfoSection />\n <Scrubber\n style={{\n width: \"100%\",\n maxWidth: \"300px\",\n height: \"35px\",\n }}\n />\n </Stack>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n disabled={\n !navigation?.canGoRightSpineItem &&\n !navigation?.canGoBottomSpineItem\n }\n onClick={() => {\n reader?.navigation.goToRightOrBottomSpineItem()\n }}\n >\n {isVerticalDirection ? (\n <RxDoubleArrowDown />\n ) : (\n <RxDoubleArrowRight />\n )}\n </IconButton>\n </HStack>\n <HStack alignItems=\"center\" justifyContent=\"center\">\n <Collapsible.Root\n open={isExtraOpen}\n flex={1}\n onOpenChange={({ open }) => {\n setIsExtraOpen(open)\n }}\n >\n <Collapsible.Trigger\n paddingY=\"3\"\n width=\"100%\"\n display=\"flex\"\n justifyContent=\"center\"\n >\n <LuChevronDown\n style={{\n transform: isExtraOpen ? \"rotate(0deg)\" : \"rotate(180deg)\",\n }}\n />\n </Collapsible.Trigger>\n <Collapsible.Content display=\"flex\" justifyContent=\"center\">\n <IconButton\n aria-label=\"Help\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={() => onItemClick(\"help\")}\n >\n <LuCircleHelp />\n </IconButton>\n <IconButton\n aria-label=\"Table of contents\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={() => onItemClick(\"toc\")}\n >\n <LuTableOfContents />\n </IconButton>\n {hasSearchEnhancer(reader) && (\n <IconButton\n aria-label=\"Search\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={() => onItemClick(\"search\")}\n >\n <LuSearch />\n </IconButton>\n )}\n {hasBookmarksEnhancer(reader) && (\n <IconButton\n aria-label=\"Search\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={() => onItemClick(\"bookmarks\")}\n >\n <BsBookmarks />\n </IconButton>\n )}\n {hasAnnotationsEnhancer(reader) && (\n <IconButton\n aria-label=\"Search\"\n size=\"lg\"\n variant=\"ghost\"\n onClick={() => onItemClick(\"annotations\")}\n >\n <LuNotebookPen />\n </IconButton>\n )}\n </Collapsible.Content>\n </Collapsible.Root>\n </HStack>\n </Stack>\n </QuickBar>\n )\n },\n)\n","import { useEffect } from \"react\"\n\nimport { useCallback } from \"react\"\n\nimport { useState } from \"react\"\n\nexport const useFullscreen = () => {\n const [isFullscreen, setIsFullscreen] = useState(false)\n\n const onToggleFullscreenClick = useCallback(() => {\n if (document.fullscreenElement) {\n return document\n .exitFullscreen()\n .catch(console.error)\n .then(() => {\n setIsFullscreen(false)\n })\n }\n\n return document.documentElement\n .requestFullscreen({ navigationUI: \"hide\" })\n .catch(console.error)\n .then(() => {\n setIsFullscreen(true)\n })\n }, [])\n\n useEffect(() => {\n function fullscreenchangeHandler() {\n setIsFullscreen(!!document.fullscreenElement)\n }\n\n document.addEventListener(\"fullscreenchange\", fullscreenchangeHandler)\n\n return () => {\n document.removeEventListener(\"fullscreenchange\", fullscreenchangeHandler)\n }\n }, [])\n\n return {\n isFullscreen,\n onToggleFullscreenClick,\n }\n}\n","import { HStack, IconButton, Stack, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport { IoIosArrowBack, IoMdMore } from \"react-icons/io\"\nimport { MdFullscreen, MdFullscreenExit } from \"react-icons/md\"\nimport { useObserve } from \"reactjrx\"\nimport { useFullscreen } from \"../common/useFullscreen\"\nimport { useReader } from \"../context/useReader\"\nimport { QuickBar } from \"./QuickBar\"\n\nexport const TopBar = memo(\n ({\n open,\n onItemClick,\n }: {\n open: boolean\n onItemClick: (item: \"more\" | \"back\") => void\n }) => {\n const reader = useReader()\n const manifest = useObserve(() => reader?.context.manifest$, [reader])\n const { isFullscreen, onToggleFullscreenClick } = useFullscreen()\n\n return (\n <QuickBar\n present={open}\n position=\"top\"\n height=\"80px\"\n justifyContent=\"space-between\"\n >\n <IconButton\n aria-label=\"left\"\n size=\"lg\"\n variant=\"ghost\"\n flexShrink={0}\n onClick={() => onItemClick(\"back\")}\n >\n <IoIosArrowBack />\n </IconButton>\n <Stack\n flex={1}\n maxW={600}\n gap={1}\n alignItems=\"center\"\n overflow=\"auto\"\n px={4}\n >\n <Text truncate maxWidth=\"100%\">\n {manifest?.title}\n </Text>\n </Stack>\n <HStack>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n onClick={() => onItemClick(\"more\")}\n >\n <IoMdMore />\n </IconButton>\n <IconButton\n aria-label=\"right\"\n size=\"lg\"\n flexShrink={0}\n variant=\"ghost\"\n onClick={onToggleFullscreenClick}\n >\n {isFullscreen ? <MdFullscreenExit /> : <MdFullscreen />}\n </IconButton>\n </HStack>\n </QuickBar>\n )\n },\n)\n","import { memo } from \"react\"\nimport { BottomBar } from \"./BottomBar\"\nimport { TopBar } from \"./TopBar\"\nimport { useQuickMenu } from \"./useQuickMenu\"\n\nexport const QuickMenu = memo(\n ({\n onItemClick,\n }: {\n onItemClick: (\n item:\n | \"annotations\"\n | \"search\"\n | \"help\"\n | \"toc\"\n | \"bookmarks\"\n | \"more\"\n | \"back\",\n ) => void\n }) => {\n const [quickMenuOpen] = useQuickMenu()\n\n return (\n <>\n <TopBar open={quickMenuOpen} onItemClick={onItemClick} />\n <BottomBar open={quickMenuOpen} onItemClick={onItemClick} />\n </>\n )\n },\n)\n","import { Link, Text } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\n\nexport const SearchListItem = memo(\n ({\n contextText = \"\",\n startOffset = 0,\n text,\n cfi = \"#\",\n onClick,\n absolutePageIndex,\n }: {\n pageIndex: number | undefined\n absolutePageIndex?: number\n contextText?: string\n startOffset?: number\n text: string\n cfi?: string\n onClick: (cfi: string) => void\n }) => {\n const charsAroundText = 15\n const before = contextText.substring(\n Math.max(startOffset - charsAroundText, 0),\n Math.max(startOffset, 0),\n )\n const after = contextText.substring(\n Math.min(startOffset + text.length, contextText.length - 1),\n Math.min(\n startOffset + text.length + charsAroundText,\n contextText.length - 1,\n ),\n )\n\n return (\n <Link\n href={cfi}\n style={{ margin: 5, overflow: \"hidden\" }}\n onClick={(e) => {\n e.preventDefault()\n\n onClick(cfi)\n }}\n display=\"flex\"\n flexDirection=\"column\"\n alignItems=\"flex-start\"\n gap={0}\n >\n <Text lineClamp={1} as=\"cite\" style={{ display: \"block\" }}>\n \"{before}\n <b>{text}</b>\n {after}\"\n </Text>\n <Text fontSize=\"sm\" color=\"gray.500\" style={{ textDecoration: \"none\" }}>\n {`Book page: ${absolutePageIndex !== undefined ? absolutePageIndex + 1 : \"unknown (not loaded)\"}`}\n </Text>\n </Link>\n )\n },\n)\n","import { Box, Heading, Input, Stack, Text } from \"@chakra-ui/react\"\nimport type React from \"react\"\nimport { memo, useCallback, useState } from \"react\"\nimport { useObserve } from \"reactjrx\"\nimport { map, startWith } from \"rxjs\"\nimport { hasSearchEnhancer, useReader } from \"../context/useReader\"\nimport { SearchListItem } from \"./SearchListItem\"\n\nexport const SearchDialogContent = memo(\n ({\n onNavigate,\n }: {\n onNavigate: () => void\n }) => {\n const [text, setText] = useState(\"\")\n const reader = useReader()\n const readerWithSearch = hasSearchEnhancer(reader) ? reader : undefined\n\n const onValueChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n setText(e.target.value)\n }\n\n const onClick = useCallback(\n (cfi: string) => {\n onNavigate()\n reader?.navigation.goToCfi(cfi)\n },\n [reader, onNavigate],\n )\n\n const search = useObserve(\n () =>\n readerWithSearch?.search.search(text).pipe(\n map((data) => ({ type: `end` as const, data })),\n startWith({ type: `start` as const }),\n ),\n [reader, text],\n )\n const searching = search?.type === \"start\"\n const results = search?.type === \"end\" ? search.data : []\n const consolidatedResults = useObserve(\n () => reader?.pagination.locate(results.slice(0, 100)),\n [results],\n )\n\n return (\n <Stack flex={1} height=\"100%\">\n <Box px={4}>\n <Input\n placeholder=\"Type something...\"\n value={text}\n onChange={onValueChange}\n borderRadius={0}\n />\n </Box>\n <Box\n px={4}\n pb={4}\n mt={2}\n flex={1}\n style={{ overflow: \"hidden\", overflowY: \"auto\" }}\n >\n {searching && <Text>Searching ...</Text>}\n {!searching && results.length === 0 && <p>There are no results</p>}\n {!searching && results.length >= 0 && (\n <Stack>\n <Heading as=\"h2\" size=\"md\">\n {results.length} result(s)\n </Heading>\n <Stack gap={0}>\n {consolidatedResults?.map((result, j) => {\n return (\n <SearchListItem\n key={j}\n contextText={\n result.meta?.range?.startContainer.parentElement\n ?.textContent ?? \"\"\n }\n pageIndex={result.meta?.itemPageIndex}\n startOffset={result.meta?.range?.startOffset ?? 0}\n text={text}\n cfi={result.cfi}\n onClick={onClick}\n absolutePageIndex={result.meta?.absolutePageIndex}\n />\n )\n })}\n </Stack>\n </Stack>\n )}\n </Box>\n </Stack>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { SearchDialogContent } from \"./SearchDialogContent\"\n\nexport const SearchDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent height=\"100%\">\n <DialogHeader>\n <DialogTitle>Search</DialogTitle>\n </DialogHeader>\n <DialogBody flex={1}>\n <SearchDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Link, Stack, Text } from \"@chakra-ui/react\"\n\nimport { List } from \"@chakra-ui/react\"\nimport React, { memo } from \"react\"\nimport { LuCircleCheck } from \"react-icons/lu\"\nimport { useObserve } from \"reactjrx\"\nimport { useReader } from \"../context/useReader\"\nimport { usePagination } from \"../pagination/usePagination\"\n\nexport const TableOfContentsDialogContent = memo(\n ({\n onNavigate,\n }: {\n onNavigate: () => void\n }) => {\n const reader = useReader()\n const { manifest, assumedRenditionLayout } =\n useObserve(() => reader?.context.state$, [reader]) ?? {}\n const { nav } = manifest ?? {}\n const pagination = usePagination()\n const toc = nav?.toc || []\n const { beginSpineItemIndex, beginPageIndexInSpineItem } = pagination ?? {}\n const currentSpineItemOrChapterPageIndex =\n (assumedRenditionLayout === \"reflowable\"\n ? beginPageIndexInSpineItem\n : beginSpineItemIndex) || 0\n\n console.log({ assumedRenditionLayout, currentSpineItemOrChapterPageIndex })\n\n let currentSubChapter = pagination?.beginChapterInfo\n\n while (currentSubChapter?.subChapter) {\n currentSubChapter = currentSubChapter?.subChapter\n }\n\n const buildTocForItem = (\n tocItem: (typeof toc)[number],\n index: number,\n lvl: number,\n ) => (\n <React.Fragment key={index}>\n <List.Item\n pl={4 * (lvl + 1)}\n style={{\n display: \"flex\",\n alignItems: \"center\",\n }}\n >\n <Link\n onClick={() => {\n onNavigate()\n\n reader?.navigation.goToUrl(tocItem.href)\n }}\n href=\"#\"\n >\n {currentSubChapter?.path === tocItem.path && (\n <List.Indicator asChild>\n <LuCircleCheck />\n </List.Indicator>\n )}\n {currentSubChapter?.path !== tocItem.path && (\n <List.Indicator asChild visibility=\"hidden\">\n <LuCircleCheck />\n </List.Indicator>\n )}\n <Stack gap={0}>\n <Text fontSize=\"md\">{tocItem.title || tocItem.path}</Text>\n {currentSubChapter?.path === tocItem.path && (\n <Text\n fontStyle=\"italic\"\n fontWeight=\"bold\"\n fontSize=\"sm\"\n >{`Currently on page ${\n currentSpineItemOrChapterPageIndex + 1\n }`}</Text>\n )}\n </Stack>\n </Link>\n </List.Item>\n {tocItem.contents.length > 0 && (\n <List.Root as=\"div\" gap={2}>\n {tocItem.contents.map((tocItem, index) =>\n buildTocForItem(tocItem, index, lvl + 1),\n )}\n </List.Root>\n )}\n </React.Fragment>\n )\n\n return (\n <List.Root gap={3} overflowY=\"auto\" py={4} flex={1}>\n {nav?.toc.map((tocItem, index) => buildTocForItem(tocItem, index, 0))}\n </List.Root>\n )\n },\n)\n","import { Button } from \"@chakra-ui/react\"\nimport { memo } from \"react\"\nimport {\n DialogActionTrigger,\n DialogBody,\n DialogCloseTrigger,\n DialogContent,\n DialogFooter,\n DialogHeader,\n DialogRoot,\n DialogTitle,\n} from \"../components/ui/dialog\"\nimport { TableOfContentsDialogContent } from \"./TableOfContentsDialogContent\"\n\nexport const TableOfContentsDialog = memo(\n ({\n open,\n setOpen,\n onNavigate,\n }: {\n open: boolean\n setOpen: (open: boolean) => void\n onNavigate: () => void\n }) => {\n return (\n <DialogRoot\n lazyMount\n placement=\"center\"\n open={open}\n onOpenChange={(e) => setOpen(e.open)}\n size={{ mdDown: \"full\", md: \"lg\" }}\n scrollBehavior=\"inside\"\n >\n <DialogContent>\n <DialogHeader>\n <DialogTitle>Table of Contents</DialogTitle>\n </DialogHeader>\n <DialogBody overflowY=\"auto\" flex={1}>\n <TableOfContentsDialogContent onNavigate={onNavigate} />\n </DialogBody>\n <DialogFooter>\n <DialogActionTrigger asChild>\n <Button variant=\"outline\">Cancel</Button>\n </DialogActionTrigger>\n </DialogFooter>\n <DialogCloseTrigger />\n </DialogContent>\n </DialogRoot>\n )\n },\n)\n","import { Presence } from \"@chakra-ui/react\"\nimport { useCallback, useState } from \"react\"\nimport { AnnotationsDialog } from \"./annotations/AnnotationsDialog\"\nimport { BookmarksDialog } from \"./bookmarks/BookmarksDialog\"\nimport { HelpDialog } from \"./help/HelpDialog\"\nimport { FloatingProgress } from \"./navigation/FloatingProgress\"\nimport { FloatingTime } from \"./navigation/FloatingTime\"\nimport { QuickMenu } from \"./quickmenu/QuickMenu\"\nimport { useQuickMenu } from \"./quickmenu/useQuickMenu\"\nimport { SearchDialog } from \"./search/SearchDialog\"\nimport { TableOfContentsDialog } from \"./toc/TableOfContentsDialog\"\n\nexport const ReactReader = ({\n enableFloatingTime = true,\n enableFloatingProgress = true,\n onItemClick,\n}: {\n enableFloatingTime?: boolean\n enableFloatingProgress?: boolean\n onItemClick?: (\n item:\n | \"annotations\"\n | \"search\"\n | \"help\"\n | \"toc\"\n | \"bookmarks\"\n | \"more\"\n | \"back\",\n ) => void\n}) => {\n const [isTableOfContentsOpen, setIsTableOfContentsOpen] = useState(false)\n const [isHelpOpen, setIsHelpOpen] = useState(false)\n const [isSearchOpen, setIsSearchOpen] = useState(false)\n const [isAnnotationsOpen, setIsAnnotationsOpen] = useState(false)\n const [isBookmarksOpen, setIsBookmarksOpen] = useState(false)\n const [quickMenuOpen, setQuickMenuOpen] = useQuickMenu()\n\n const onNavigate = useCallback(() => {\n setIsTableOfContentsOpen(false)\n setIsHelpOpen(false)\n setIsSearchOpen(false)\n setIsAnnotationsOpen(false)\n setIsBookmarksOpen(false)\n setQuickMenuOpen(false)\n }, [setQuickMenuOpen])\n\n const _onItemClick: NonNullable<typeof onItemClick> = useCallback(\n (item) => {\n if (item === \"annotations\") {\n setIsAnnotationsOpen(true)\n } else if (item === \"search\") {\n setIsSearchOpen(true)\n } else if (item === \"help\") {\n setIsHelpOpen(true)\n } else if (item === \"toc\") {\n setIsTableOfContentsOpen(true)\n } else if (item === \"bookmarks\") {\n setIsBookmarksOpen(true)\n }\n onItemClick?.(item)\n },\n [onItemClick],\n )\n\n return (\n <>\n {enableFloatingProgress && (\n <Presence\n present={!quickMenuOpen}\n animationName={{ _open: \"fade-in\", _closed: \"fade-out\" }}\n animationDuration=\"moderate\"\n >\n <FloatingProgress />\n </Presence>\n )}\n <QuickMenu onItemClick={_onItemClick} />\n <HelpDialog open={isHelpOpen} setOpen={setIsHelpOpen} />\n <TableOfContentsDialog\n open={isTableOfContentsOpen}\n setOpen={setIsTableOfContentsOpen}\n onNavigate={onNavigate}\n />\n <SearchDialog\n open={isSearchOpen}\n setOpen={setIsSearchOpen}\n onNavigate={onNavigate}\n />\n <AnnotationsDialog\n open={isAnnotationsOpen}\n setOpen={setIsAnnotationsOpen}\n onNavigate={onNavigate}\n />\n <BookmarksDialog\n open={isBookmarksOpen}\n setOpen={setIsBookmarksOpen}\n onNavigate={onNavigate}\n />\n <Presence\n present={enableFloatingTime || quickMenuOpen}\n animationName={{ _open: \"fade-in\", _closed: \"fade-out\" }}\n animationDuration=\"slow\"\n overflow=\"hidden\"\n >\n <FloatingTime />\n </Presence>\n </>\n )\n}\n"],"names":["ReaderContext","createContext","signal","ReactReaderProvider","memo","children","reader","quickMenuOpen","onQuickMenuOpenChange","quickMenuSignal","useSignal","onQuickMenuOpenChangeLiveRef","useLiveRef","value","useMemo","useEffect","useSubscribe","tap","jsx","CloseButton","React","props","ref","ChakraIconButton","LuX","DialogContent","portalled","portalRef","backdrop","rest","Portal","ChakraDialog","DialogCloseTrigger","DialogRoot","DialogFooter","DialogHeader","DialogBody","DialogTitle","DialogActionTrigger","useReader","useContext","hasSearchEnhancer","hasBookmarksEnhancer","hasAnnotationsEnhancer","AnnotationsDialogContent","onNavigate","readerWithAnnotations","consolidatedHighlights","useObserve","switchMap","highlights","mapItemToListEntry","item","index","List","jsxs","Link","LuNotebookPen","Stack","Text","_a","AnnotationsDialog","open","setOpen","e","Button","BookmarksDialogContent","readerWithBookmarks","consolidatedBookmarks","items","_e","_d","BookmarksDialog","HelpDialog","Heading","HStack","Kbd","LuArrowBigRight","LuArrowBigLeft","name","version","usePagination","combineLatest","map","state","context","isOnlyImages","NEVER","FloatingProgress","pagination","roundedProgress","displayableProgress","Box","useTime","time","setTime","useState","interval","TimeIndicator","useQuickMenu","useSignalValue","FloatingTime","ToggleTip","showArrow","content","ChakraPopover","InfoTip","IconButton","HiOutlineInformationCircle","ProgressBar","ChakraProgress","React__namespace","info","ProgressRoot","ProgressValueText","useNavigationContext","hasOnlyOnePage","isBeginWithinChapter","isEndWithinChapter","beginPageIndex","endPageIndex","leftPageIndex","rightPageIndex","a","b","beginAndEndAreDifferent","totalApproximatePages","PaginationInfoSection","progress","buildTitleChain","chapterInfo","chapterTitle","Fragment","QuickBar","position","Presence","ChakraRcSlider","chakra","RcSlider","ThemedSlider","useSliderValues","isUsingSpread","currentRealPage","currentPage","valueSignal","min","max","Scrubber","manifest","reverse","step","isScrubberWithinChapter","onChange","useCallback","values","pageIndex","BottomBar","onItemClick","navigation","settings","isVerticalDirection","isExtraOpen","setIsExtraOpen","RxDoubleArrowUp","RxDoubleArrowLeft","RxDoubleArrowDown","RxDoubleArrowRight","Collapsible","LuChevronDown","LuCircleHelp","LuTableOfContents","LuSearch","BsBookmarks","useFullscreen","isFullscreen","setIsFullscreen","onToggleFullscreenClick","fullscreenchangeHandler","TopBar","IoIosArrowBack","IoMdMore","MdFullscreenExit","MdFullscreen","QuickMenu","SearchListItem","contextText","startOffset","text","cfi","onClick","absolutePageIndex","before","after","SearchDialogContent","setText","readerWithSearch","onValueChange","search","data","startWith","searching","results","consolidatedResults","Input","result","j","_c","_b","_f","_g","SearchDialog","TableOfContentsDialogContent","assumedRenditionLayout","nav","beginSpineItemIndex","beginPageIndexInSpineItem","currentSpineItemOrChapterPageIndex","currentSubChapter","buildTocForItem","tocItem","lvl","LuCircleCheck","TableOfContentsDialog","ReactReader","enableFloatingTime","enableFloatingProgress","isTableOfContentsOpen","setIsTableOfContentsOpen","isHelpOpen","setIsHelpOpen","isSearchOpen","setIsSearchOpen","isAnnotationsOpen","setIsAnnotationsOpen","isBookmarksOpen","setIsBookmarksOpen","setQuickMenuOpen","_onItemClick"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare const BottomBar: import('react').MemoExoticComponent<({ open, onItemClick, }: {
2
+ open: boolean;
3
+ onItemClick: (item: "annotations" | "search" | "help" | "toc" | "bookmarks") => void;
4
+ }) => import("react/jsx-runtime").JSX.Element>;
@@ -0,0 +1,3 @@
1
+ export declare const QuickMenu: import('react').MemoExoticComponent<({ onItemClick, }: {
2
+ onItemClick: (item: "annotations" | "search" | "help" | "toc" | "bookmarks" | "more" | "back") => void;
3
+ }) => import("react/jsx-runtime").JSX.Element>;
@@ -0,0 +1,3 @@
1
+ import { ComponentProps } from 'react';
2
+ import { ThemedSlider } from './ThemedSlider';
3
+ export declare const Scrubber: (props: ComponentProps<typeof ThemedSlider>) => import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,4 @@
1
+ export declare const TopBar: import('react').MemoExoticComponent<({ open, onItemClick, }: {
2
+ open: boolean;
3
+ onItemClick: (item: "more" | "back") => void;
4
+ }) => import("react/jsx-runtime").JSX.Element>;
@@ -0,0 +1 @@
1
+ export declare const config: import('@chakra-ui/react').SystemConfig;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@prose-reader/react-reader",
3
3
  "private": false,
4
- "version": "1.187.0",
4
+ "version": "1.188.0",
5
5
  "type": "module",
6
6
  "types": "./dist/index.d.ts",
7
7
  "exports": {
@@ -30,6 +30,9 @@
30
30
  "@chakra-ui/react": "3.x",
31
31
  "@emotion/react": "11.x",
32
32
  "@prose-reader/core": "^1.169.0",
33
+ "@prose-reader/enhancer-annotations": "^1.169.0",
34
+ "@prose-reader/enhancer-bookmarks": "^1.169.0",
35
+ "@prose-reader/enhancer-gestures": "^1.169.0",
33
36
  "@prose-reader/enhancer-search": "^1.169.0",
34
37
  "rc-slider": "11.1.x",
35
38
  "react": "19.x || 18.x",
@@ -40,7 +43,13 @@
40
43
  "peerDependenciesMeta": {
41
44
  "@prose-reader/enhancer-search": {
42
45
  "optional": true
46
+ },
47
+ "@prose-reader/enhancer-annotations": {
48
+ "optional": true
49
+ },
50
+ "@prose-reader/enhancer-bookmarks": {
51
+ "optional": true
43
52
  }
44
53
  },
45
- "gitHead": "659bb0401d13b671a3002190fbd22f861caf7059"
54
+ "gitHead": "a6ddf8db2341a6d8f68c76d129d8b9b26c6acfb7"
46
55
  }
@@ -1,4 +0,0 @@
1
- import { Reader } from '@prose-reader/core';
2
- import { SearchEnhancerAPI } from '@prose-reader/enhancer-search';
3
- export declare const useReader: () => Reader | undefined;
4
- export declare const hasSearchEnhancer: (reader?: Reader) => reader is Reader & SearchEnhancerAPI;
@@ -1,6 +0,0 @@
1
- export declare const BottomBar: import('react').MemoExoticComponent<({ open, onTableOfContentsClick, onHelpClick, onSearchClick, }: {
2
- open: boolean;
3
- onTableOfContentsClick: () => void;
4
- onHelpClick: () => void;
5
- onSearchClick: () => void;
6
- }) => import("react/jsx-runtime").JSX.Element>;
@@ -1,7 +0,0 @@
1
- export declare const QuickMenu: import('react').MemoExoticComponent<({ onBackClick, onMoreClick, onTableOfContentsClick, onHelpClick, onSearchClick, }: {
2
- onBackClick: () => void;
3
- onMoreClick: () => void;
4
- onTableOfContentsClick: () => void;
5
- onHelpClick: () => void;
6
- onSearchClick: () => void;
7
- }) => import("react/jsx-runtime").JSX.Element>;
@@ -1 +0,0 @@
1
- export declare const Scrubber: () => import("react/jsx-runtime").JSX.Element | null;
@@ -1,5 +0,0 @@
1
- export declare const TopBar: ({ open, onBackClick, onMoreClick, }: {
2
- open: boolean;
3
- onBackClick: () => void;
4
- onMoreClick: () => void;
5
- }) => import("react/jsx-runtime").JSX.Element;
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes