@vertesia/ui 0.80.0-dev.20251121 → 0.80.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.
- package/README.md +105 -0
- package/lib/esm/core/components/MenuList.js +2 -5
- package/lib/esm/core/components/MenuList.js.map +1 -1
- package/lib/esm/core/components/MessageBox.js +1 -1
- package/lib/esm/core/components/MessageBox.js.map +1 -1
- package/lib/esm/core/components/shadcn/dialog.js +16 -2
- package/lib/esm/core/components/shadcn/dialog.js.map +1 -1
- package/lib/esm/core/components/shadcn/filters/filter/SelectFilter.js +6 -9
- package/lib/esm/core/components/shadcn/filters/filter/SelectFilter.js.map +1 -1
- package/lib/esm/core/components/shadcn/filters/filterBar.js +1 -1
- package/lib/esm/core/components/shadcn/filters/filterBar.js.map +1 -1
- package/lib/esm/core/components/shadcn/selectBox.js +23 -5
- package/lib/esm/core/components/shadcn/selectBox.js.map +1 -1
- package/lib/esm/core/components/shadcn/tabs.js +3 -3
- package/lib/esm/core/components/shadcn/tabs.js.map +1 -1
- package/lib/esm/env/index.js +3 -0
- package/lib/esm/env/index.js.map +1 -1
- package/lib/esm/features/agent/chat/AgentChart.js +184 -0
- package/lib/esm/features/agent/chat/AgentChart.js.map +1 -0
- package/lib/esm/features/agent/chat/ModernAgentConversation.js +87 -10
- package/lib/esm/features/agent/chat/ModernAgentConversation.js.map +1 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/AllMessagesMixed.js +6 -2
- package/lib/esm/features/agent/chat/ModernAgentOutput/AllMessagesMixed.js.map +1 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/Header.js +4 -4
- package/lib/esm/features/agent/chat/ModernAgentOutput/Header.js.map +1 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/InlineSlidingPlanPanel.js +4 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/InlineSlidingPlanPanel.js.map +1 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/MessageInput.js +12 -4
- package/lib/esm/features/agent/chat/ModernAgentOutput/MessageInput.js.map +1 -1
- package/lib/esm/features/agent/chat/ModernAgentOutput/MessageItem.js +60 -56
- package/lib/esm/features/agent/chat/ModernAgentOutput/MessageItem.js.map +1 -1
- package/lib/esm/features/agent/chat/index.js +1 -0
- package/lib/esm/features/agent/chat/index.js.map +1 -1
- package/lib/esm/features/agent/createChartTool.js +354 -0
- package/lib/esm/features/agent/createChartTool.js.map +1 -0
- package/lib/esm/features/agent/examples.js +295 -0
- package/lib/esm/features/agent/examples.js.map +1 -0
- package/lib/esm/features/agent/index.js +2 -0
- package/lib/esm/features/agent/index.js.map +1 -1
- package/lib/esm/features/agent/visualization.js +165 -0
- package/lib/esm/features/agent/visualization.js.map +1 -0
- package/lib/esm/features/facets/CollectionsFacetsNav.js +5 -1
- package/lib/esm/features/facets/CollectionsFacetsNav.js.map +1 -1
- package/lib/esm/features/index.js +1 -0
- package/lib/esm/features/index.js.map +1 -1
- package/lib/esm/features/layout/GenericPageNavHeader.js +14 -4
- package/lib/esm/features/layout/GenericPageNavHeader.js.map +1 -1
- package/lib/esm/features/magic-pdf/AnnotatedImageSlider.js +268 -0
- package/lib/esm/features/magic-pdf/AnnotatedImageSlider.js.map +1 -0
- package/lib/esm/features/magic-pdf/DownloadPopover.js +11 -11
- package/lib/esm/features/magic-pdf/DownloadPopover.js.map +1 -1
- package/lib/esm/features/magic-pdf/ExtractedContentView.js +77 -0
- package/lib/esm/features/magic-pdf/ExtractedContentView.js.map +1 -0
- package/lib/esm/features/magic-pdf/MagicPdfProvider.js +242 -0
- package/lib/esm/features/magic-pdf/MagicPdfProvider.js.map +1 -0
- package/lib/esm/features/magic-pdf/MagicPdfView.js +41 -47
- package/lib/esm/features/magic-pdf/MagicPdfView.js.map +1 -1
- package/lib/esm/features/pdf-viewer/PdfPageRenderer.js +261 -0
- package/lib/esm/features/pdf-viewer/PdfPageRenderer.js.map +1 -0
- package/lib/esm/features/pdf-viewer/PdfPageSlider.js +276 -0
- package/lib/esm/features/pdf-viewer/PdfPageSlider.js.map +1 -0
- package/lib/esm/features/pdf-viewer/SimplePdfViewer.js +71 -0
- package/lib/esm/features/pdf-viewer/SimplePdfViewer.js.map +1 -0
- package/lib/esm/features/pdf-viewer/index.js +4 -0
- package/lib/esm/features/pdf-viewer/index.js.map +1 -0
- package/lib/esm/features/store/collections/EditCollectionView.js +3 -5
- package/lib/esm/features/store/collections/EditCollectionView.js.map +1 -1
- package/lib/esm/features/store/collections/SharedPropsEditor.js +1 -2
- package/lib/esm/features/store/collections/SharedPropsEditor.js.map +1 -1
- package/lib/esm/features/store/objects/DocumentSearchResults.js +0 -7
- package/lib/esm/features/store/objects/DocumentSearchResults.js.map +1 -1
- package/lib/esm/features/store/objects/components/ContentOverview.js +273 -83
- package/lib/esm/features/store/objects/components/ContentOverview.js.map +1 -1
- package/lib/esm/features/store/objects/components/useContentPanelHooks.js +153 -0
- package/lib/esm/features/store/objects/components/useContentPanelHooks.js.map +1 -0
- package/lib/esm/features/store/objects/layout/DocumentTableColumn.js +3 -3
- package/lib/esm/features/store/objects/layout/DocumentTableColumn.js.map +1 -1
- package/lib/esm/features/store/objects/layout/renderers.js +13 -0
- package/lib/esm/features/store/objects/layout/renderers.js.map +1 -1
- package/lib/esm/features/utils/index.js +2 -0
- package/lib/esm/features/utils/index.js.map +1 -1
- package/lib/esm/features/utils/mimeType.js +8 -0
- package/lib/esm/features/utils/mimeType.js.map +1 -1
- package/lib/esm/features/utils/print.js +181 -0
- package/lib/esm/features/utils/print.js.map +1 -0
- package/lib/esm/features/utils/workflowStatus.js +43 -0
- package/lib/esm/features/utils/workflowStatus.js.map +1 -0
- package/lib/esm/router/HistoryNavigator.js +22 -2
- package/lib/esm/router/HistoryNavigator.js.map +1 -1
- package/lib/esm/shell/login/UserInfo.js +2 -1
- package/lib/esm/shell/login/UserInfo.js.map +1 -1
- package/lib/esm/shell/login/UserSessionMenu.js +7 -1
- package/lib/esm/shell/login/UserSessionMenu.js.map +1 -1
- package/lib/esm/widgets/form/Form.js +6 -2
- package/lib/esm/widgets/form/Form.js.map +1 -1
- package/lib/esm/widgets/markdown/MarkdownRenderer.js +226 -4
- package/lib/esm/widgets/markdown/MarkdownRenderer.js.map +1 -1
- package/lib/esm/widgets/schema-editor/ManagedSchema.js +0 -3
- package/lib/esm/widgets/schema-editor/ManagedSchema.js.map +1 -1
- package/lib/esm/widgets/schema-editor/json-schema4-utils.js +1 -1
- package/lib/esm/widgets/schema-editor/json-schema4-utils.js.map +1 -1
- package/lib/esm/widgets/xml-viewer/components/XMLViewer.js +18 -9
- package/lib/esm/widgets/xml-viewer/components/XMLViewer.js.map +1 -1
- package/lib/esm/widgets/xml-viewer/constants/index.js +10 -0
- package/lib/esm/widgets/xml-viewer/constants/index.js.map +1 -1
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/types/core/components/MessageBox.d.ts.map +1 -1
- package/lib/types/core/components/shadcn/dialog.d.ts +2 -1
- package/lib/types/core/components/shadcn/dialog.d.ts.map +1 -1
- package/lib/types/core/components/shadcn/filters/filterBar.d.ts.map +1 -1
- package/lib/types/core/components/shadcn/selectBox.d.ts +5 -1
- package/lib/types/core/components/shadcn/selectBox.d.ts.map +1 -1
- package/lib/types/core/components/shadcn/tabs.d.ts +3 -1
- package/lib/types/core/components/shadcn/tabs.d.ts.map +1 -1
- package/lib/types/env/index.d.ts +2 -0
- package/lib/types/env/index.d.ts.map +1 -1
- package/lib/types/features/agent/chat/AgentChart.d.ts +48 -0
- package/lib/types/features/agent/chat/AgentChart.d.ts.map +1 -0
- package/lib/types/features/agent/chat/ModernAgentConversation.d.ts.map +1 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/AllMessagesMixed.d.ts +3 -2
- package/lib/types/features/agent/chat/ModernAgentOutput/AllMessagesMixed.d.ts.map +1 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/Header.d.ts +2 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/Header.d.ts.map +1 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/InlineSlidingPlanPanel.d.ts +4 -2
- package/lib/types/features/agent/chat/ModernAgentOutput/InlineSlidingPlanPanel.d.ts.map +1 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/MessageInput.d.ts +2 -4
- package/lib/types/features/agent/chat/ModernAgentOutput/MessageInput.d.ts.map +1 -1
- package/lib/types/features/agent/chat/ModernAgentOutput/MessageItem.d.ts.map +1 -1
- package/lib/types/features/agent/chat/index.d.ts +1 -0
- package/lib/types/features/agent/chat/index.d.ts.map +1 -1
- package/lib/types/features/agent/createChartTool.d.ts +178 -0
- package/lib/types/features/agent/createChartTool.d.ts.map +1 -0
- package/lib/types/features/agent/examples.d.ts +59 -0
- package/lib/types/features/agent/examples.d.ts.map +1 -0
- package/lib/types/features/agent/index.d.ts +2 -0
- package/lib/types/features/agent/index.d.ts.map +1 -1
- package/lib/types/features/agent/visualization.d.ts +95 -0
- package/lib/types/features/agent/visualization.d.ts.map +1 -0
- package/lib/types/features/facets/CollectionsFacetsNav.d.ts.map +1 -1
- package/lib/types/features/index.d.ts +1 -0
- package/lib/types/features/index.d.ts.map +1 -1
- package/lib/types/features/layout/GenericPageNavHeader.d.ts.map +1 -1
- package/lib/types/features/magic-pdf/AnnotatedImageSlider.d.ts +13 -0
- package/lib/types/features/magic-pdf/AnnotatedImageSlider.d.ts.map +1 -0
- package/lib/types/features/magic-pdf/DownloadPopover.d.ts.map +1 -1
- package/lib/types/features/magic-pdf/ExtractedContentView.d.ts +8 -0
- package/lib/types/features/magic-pdf/ExtractedContentView.d.ts.map +1 -0
- package/lib/types/features/magic-pdf/MagicPdfProvider.d.ts +58 -0
- package/lib/types/features/magic-pdf/MagicPdfProvider.d.ts.map +1 -0
- package/lib/types/features/magic-pdf/MagicPdfView.d.ts +1 -1
- package/lib/types/features/magic-pdf/MagicPdfView.d.ts.map +1 -1
- package/lib/types/features/pdf-viewer/PdfPageRenderer.d.ts +83 -0
- package/lib/types/features/pdf-viewer/PdfPageRenderer.d.ts.map +1 -0
- package/lib/types/features/pdf-viewer/PdfPageSlider.d.ts +29 -0
- package/lib/types/features/pdf-viewer/PdfPageSlider.d.ts.map +1 -0
- package/lib/types/features/pdf-viewer/SimplePdfViewer.d.ts +19 -0
- package/lib/types/features/pdf-viewer/SimplePdfViewer.d.ts.map +1 -0
- package/lib/types/features/pdf-viewer/index.d.ts +4 -0
- package/lib/types/features/pdf-viewer/index.d.ts.map +1 -0
- package/lib/types/features/store/collections/EditCollectionView.d.ts.map +1 -1
- package/lib/types/features/store/collections/SharedPropsEditor.d.ts.map +1 -1
- package/lib/types/features/store/objects/DocumentSearchResults.d.ts.map +1 -1
- package/lib/types/features/store/objects/components/ContentOverview.d.ts.map +1 -1
- package/lib/types/features/store/objects/components/useContentPanelHooks.d.ts +30 -0
- package/lib/types/features/store/objects/components/useContentPanelHooks.d.ts.map +1 -0
- package/lib/types/features/store/objects/layout/renderers.d.ts.map +1 -1
- package/lib/types/features/utils/index.d.ts +2 -0
- package/lib/types/features/utils/index.d.ts.map +1 -1
- package/lib/types/features/utils/mimeType.d.ts +1 -0
- package/lib/types/features/utils/mimeType.d.ts.map +1 -1
- package/lib/types/features/utils/print.d.ts +10 -0
- package/lib/types/features/utils/print.d.ts.map +1 -0
- package/lib/types/features/utils/workflowStatus.d.ts +10 -0
- package/lib/types/features/utils/workflowStatus.d.ts.map +1 -0
- package/lib/types/router/HistoryNavigator.d.ts +3 -0
- package/lib/types/router/HistoryNavigator.d.ts.map +1 -1
- package/lib/types/shell/login/UserInfo.d.ts.map +1 -1
- package/lib/types/shell/login/UserSessionMenu.d.ts.map +1 -1
- package/lib/types/widgets/form/Form.d.ts.map +1 -1
- package/lib/types/widgets/markdown/MarkdownRenderer.d.ts +5 -1
- package/lib/types/widgets/markdown/MarkdownRenderer.d.ts.map +1 -1
- package/lib/types/widgets/schema-editor/ManagedSchema.d.ts.map +1 -1
- package/lib/types/widgets/xml-viewer/components/XMLViewer.d.ts.map +1 -1
- package/lib/types/widgets/xml-viewer/constants/index.d.ts +10 -0
- package/lib/types/widgets/xml-viewer/constants/index.d.ts.map +1 -1
- package/lib/vertesia-ui-core.js +1 -1
- package/lib/vertesia-ui-core.js.map +1 -1
- package/lib/vertesia-ui-env.js +1 -1
- package/lib/vertesia-ui-env.js.map +1 -1
- package/lib/vertesia-ui-features.js +1 -1
- package/lib/vertesia-ui-features.js.map +1 -1
- package/lib/vertesia-ui-layout.js +1 -1
- package/lib/vertesia-ui-layout.js.map +1 -1
- package/lib/vertesia-ui-router.js +1 -1
- package/lib/vertesia-ui-router.js.map +1 -1
- package/lib/vertesia-ui-session.js +1 -1
- package/lib/vertesia-ui-session.js.map +1 -1
- package/lib/vertesia-ui-shell.js +1 -1
- package/lib/vertesia-ui-shell.js.map +1 -1
- package/lib/vertesia-ui-widgets.js +1 -1
- package/lib/vertesia-ui-widgets.js.map +1 -1
- package/package.json +11 -8
- package/src/core/components/MenuList.tsx +3 -6
- package/src/core/components/MessageBox.tsx +7 -2
- package/src/core/components/SelectBox.tsx +1 -1
- package/src/core/components/shadcn/dialog.tsx +19 -1
- package/src/core/components/shadcn/filters/filter/SelectFilter.tsx +31 -31
- package/src/core/components/shadcn/filters/filterBar.tsx +1 -0
- package/src/core/components/shadcn/selectBox.tsx +32 -6
- package/src/core/components/shadcn/tabs.tsx +3 -2
- package/src/env/index.ts +5 -0
- package/src/features/agent/CHART_INSTRUCTIONS.md +228 -0
- package/src/features/agent/chat/AgentChart.tsx +601 -0
- package/src/features/agent/chat/ModernAgentConversation.tsx +123 -11
- package/src/features/agent/chat/ModernAgentOutput/AllMessagesMixed.tsx +8 -2
- package/src/features/agent/chat/ModernAgentOutput/Header.tsx +12 -2
- package/src/features/agent/chat/ModernAgentOutput/InlineSlidingPlanPanel.tsx +6 -1
- package/src/features/agent/chat/ModernAgentOutput/MessageInput.tsx +15 -10
- package/src/features/agent/chat/ModernAgentOutput/MessageItem.tsx +122 -87
- package/src/features/agent/chat/index.ts +1 -0
- package/src/features/agent/createChartTool.ts +364 -0
- package/src/features/agent/examples.ts +321 -0
- package/src/features/agent/index.ts +2 -0
- package/src/features/agent/visualization.ts +227 -0
- package/src/features/facets/CollectionsFacetsNav.tsx +5 -1
- package/src/features/index.ts +1 -0
- package/src/features/layout/GenericPageNavHeader.tsx +15 -4
- package/src/features/magic-pdf/AnnotatedImageSlider.tsx +482 -0
- package/src/features/magic-pdf/DownloadPopover.tsx +45 -40
- package/src/features/magic-pdf/ExtractedContentView.tsx +132 -0
- package/src/features/magic-pdf/MagicPdfProvider.tsx +297 -0
- package/src/features/magic-pdf/MagicPdfView.tsx +184 -91
- package/src/features/pdf-viewer/PdfPageRenderer.tsx +612 -0
- package/src/features/pdf-viewer/PdfPageSlider.tsx +473 -0
- package/src/features/pdf-viewer/SimplePdfViewer.tsx +142 -0
- package/src/features/pdf-viewer/index.ts +3 -0
- package/src/features/store/collections/EditCollectionView.tsx +3 -5
- package/src/features/store/collections/SharedPropsEditor.tsx +1 -2
- package/src/features/store/objects/DocumentSearchResults.tsx +0 -7
- package/src/features/store/objects/components/ContentOverview.tsx +677 -210
- package/src/features/store/objects/components/useContentPanelHooks.ts +169 -0
- package/src/features/store/objects/layout/DocumentTableColumn.tsx +3 -3
- package/src/features/store/objects/layout/knowledge.md +1 -0
- package/src/features/store/objects/layout/renderers.tsx +25 -0
- package/src/features/utils/index.ts +3 -1
- package/src/features/utils/mimeType.ts +10 -1
- package/src/features/utils/print.ts +189 -0
- package/src/features/utils/workflowStatus.ts +44 -0
- package/src/router/HistoryNavigator.ts +30 -2
- package/src/shell/login/UserInfo.tsx +2 -0
- package/src/shell/login/UserSessionMenu.tsx +12 -1
- package/src/widgets/form/Form.tsx +8 -3
- package/src/widgets/markdown/MarkdownRenderer.tsx +350 -6
- package/src/widgets/schema-editor/ManagedSchema.ts +0 -3
- package/src/widgets/schema-editor/json-schema4-utils.ts +1 -1
- package/src/widgets/xml-viewer/components/XMLViewer.tsx +22 -10
- package/src/widgets/xml-viewer/constants/index.ts +11 -0
- package/lib/esm/features/magic-pdf/PageSlider.js +0 -70
- package/lib/esm/features/magic-pdf/PageSlider.js.map +0 -1
- package/lib/esm/features/magic-pdf/PdfPageProvider.js +0 -188
- package/lib/esm/features/magic-pdf/PdfPageProvider.js.map +0 -1
- package/lib/esm/features/magic-pdf/TextPageView.js +0 -62
- package/lib/esm/features/magic-pdf/TextPageView.js.map +0 -1
- package/lib/esm/features/magic-pdf/useResizeOnDrag.js +0 -34
- package/lib/esm/features/magic-pdf/useResizeOnDrag.js.map +0 -1
- package/lib/types/features/magic-pdf/PageSlider.d.ts +0 -9
- package/lib/types/features/magic-pdf/PageSlider.d.ts.map +0 -1
- package/lib/types/features/magic-pdf/PdfPageProvider.d.ts +0 -39
- package/lib/types/features/magic-pdf/PdfPageProvider.d.ts.map +0 -1
- package/lib/types/features/magic-pdf/TextPageView.d.ts +0 -8
- package/lib/types/features/magic-pdf/TextPageView.d.ts.map +0 -1
- package/lib/types/features/magic-pdf/useResizeOnDrag.d.ts +0 -9
- package/lib/types/features/magic-pdf/useResizeOnDrag.d.ts.map +0 -1
- package/src/features/magic-pdf/PageSlider.tsx +0 -142
- package/src/features/magic-pdf/PdfPageProvider.tsx +0 -310
- package/src/features/magic-pdf/TextPageView.tsx +0 -91
- package/src/features/magic-pdf/useResizeOnDrag.ts +0 -42
|
@@ -1,310 +0,0 @@
|
|
|
1
|
-
import { useUserSession } from "@vertesia/ui/session";
|
|
2
|
-
import { VertesiaClient } from "@vertesia/client";
|
|
3
|
-
import {
|
|
4
|
-
ContentObject,
|
|
5
|
-
DocumentMetadata,
|
|
6
|
-
GetFileUrlResponse,
|
|
7
|
-
} from "@vertesia/common";
|
|
8
|
-
import React, { createContext, useEffect, useState } from "react";
|
|
9
|
-
|
|
10
|
-
const DEFAULT_PAGE_COUNT = 10;
|
|
11
|
-
const ADVANCED_PROCESSING_PREFIX = "magic-pdf";
|
|
12
|
-
|
|
13
|
-
interface PdfPagesInfo {
|
|
14
|
-
count: number;
|
|
15
|
-
urls: string[];
|
|
16
|
-
originalUrls: string[];
|
|
17
|
-
annotatedUrls: string[];
|
|
18
|
-
instrumentedUrls: string[];
|
|
19
|
-
layoutProvider: PageLayoutProvider;
|
|
20
|
-
markdownProvider: PageMarkdownProvider;
|
|
21
|
-
xml: string;
|
|
22
|
-
xmlPages: string[];
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
class PageLayoutProvider {
|
|
26
|
-
layoutUrls: string[] = [];
|
|
27
|
-
cache: string[];
|
|
28
|
-
constructor(public totalPages: number) {
|
|
29
|
-
this.cache = new Array<string>(totalPages);
|
|
30
|
-
}
|
|
31
|
-
async loadUrls(vertesia: VertesiaClient, objectId: string) {
|
|
32
|
-
const layoutPromises: Promise<GetFileUrlResponse>[] = [];
|
|
33
|
-
for (let i = 0; i < this.totalPages; i++) {
|
|
34
|
-
layoutPromises.push(getLayoutUrlForPage(vertesia, objectId, i + 1));
|
|
35
|
-
}
|
|
36
|
-
const layoutUrls = await Promise.all(layoutPromises);
|
|
37
|
-
this.layoutUrls = layoutUrls.map((r) => r.url);
|
|
38
|
-
}
|
|
39
|
-
async getPageLayout(page: number) {
|
|
40
|
-
const index = page - 1;
|
|
41
|
-
let content = this.cache[index];
|
|
42
|
-
if (content === undefined) {
|
|
43
|
-
const url = this.layoutUrls[index];
|
|
44
|
-
content = await fetch(url, { method: "GET" }).then((r) => {
|
|
45
|
-
if (r.ok) {
|
|
46
|
-
return r.text();
|
|
47
|
-
} else {
|
|
48
|
-
throw new Error(
|
|
49
|
-
"Failed to fetch json layout: " + r.statusText,
|
|
50
|
-
);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
this.cache[index] = content;
|
|
54
|
-
}
|
|
55
|
-
return content;
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
class PageMarkdownProvider {
|
|
60
|
-
markdownUrls: string[] = [];
|
|
61
|
-
cache: string[];
|
|
62
|
-
constructor(public totalPages: number) {
|
|
63
|
-
this.cache = new Array<string>(totalPages);
|
|
64
|
-
}
|
|
65
|
-
async loadUrls(vertesia: VertesiaClient, objectId: string) {
|
|
66
|
-
const markdownPromises: Promise<GetFileUrlResponse>[] = [];
|
|
67
|
-
for (let i = 0; i < this.totalPages; i++) {
|
|
68
|
-
markdownPromises.push(getMarkdownUrlForPage(vertesia, objectId, i + 1));
|
|
69
|
-
}
|
|
70
|
-
const markdownUrls = await Promise.all(markdownPromises);
|
|
71
|
-
this.markdownUrls = markdownUrls.map((r) => r.url);
|
|
72
|
-
}
|
|
73
|
-
async getPageMarkdown(page: number) {
|
|
74
|
-
const index = page - 1;
|
|
75
|
-
let content = this.cache[index];
|
|
76
|
-
if (content === undefined) {
|
|
77
|
-
const url = this.markdownUrls[index];
|
|
78
|
-
content = await fetch(url, { method: "GET" }).then((r) => {
|
|
79
|
-
if (r.ok) {
|
|
80
|
-
return r.text();
|
|
81
|
-
} else {
|
|
82
|
-
throw new Error(
|
|
83
|
-
"Failed to fetch markdown: " + r.statusText,
|
|
84
|
-
);
|
|
85
|
-
}
|
|
86
|
-
});
|
|
87
|
-
this.cache[index] = content;
|
|
88
|
-
}
|
|
89
|
-
return content;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
const PdfPageContext = createContext<PdfPagesInfo | undefined>(undefined);
|
|
94
|
-
|
|
95
|
-
interface PdfPageProviderProps {
|
|
96
|
-
object: ContentObject;
|
|
97
|
-
children: React.ReactNode;
|
|
98
|
-
}
|
|
99
|
-
export function PdfPageProvider({ children, object }: PdfPageProviderProps) {
|
|
100
|
-
const { client } = useUserSession();
|
|
101
|
-
const [info, setInfo] = useState<PdfPagesInfo>();
|
|
102
|
-
useEffect(() => {
|
|
103
|
-
const page_count =
|
|
104
|
-
(object.metadata as DocumentMetadata).page_count ||
|
|
105
|
-
DEFAULT_PAGE_COUNT;
|
|
106
|
-
getPdfPagesInfo(client, object, page_count).then(setInfo);
|
|
107
|
-
}, [object.id]);
|
|
108
|
-
|
|
109
|
-
return (
|
|
110
|
-
info && (
|
|
111
|
-
<PdfPageContext.Provider value={info}>
|
|
112
|
-
{children}
|
|
113
|
-
</PdfPageContext.Provider>
|
|
114
|
-
)
|
|
115
|
-
);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
function getBasePath(objectId: string) {
|
|
119
|
-
return `${ADVANCED_PROCESSING_PREFIX}/${objectId}`;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
function getPageImagePath(objectId: string, pageNumber: number, ext = ".jpg") {
|
|
123
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}${ext}`;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
function getPageAnnotatedImagePath(
|
|
127
|
-
objectId: string,
|
|
128
|
-
pageNumber: number,
|
|
129
|
-
ext = ".jpg",
|
|
130
|
-
) {
|
|
131
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}-annotated${ext}`;
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
function getPageInstrumentedImagePath(
|
|
135
|
-
objectId: string,
|
|
136
|
-
pageNumber: number,
|
|
137
|
-
ext = ".jpg",
|
|
138
|
-
) {
|
|
139
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}.instrumented${ext}`;
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
function getPageOriginalImagePath(
|
|
143
|
-
objectId: string,
|
|
144
|
-
pageNumber: number,
|
|
145
|
-
ext = ".jpg",
|
|
146
|
-
) {
|
|
147
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}.original${ext}`;
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
function getLayoutJsonPath(objectId: string, pageNumber: number) {
|
|
151
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}.layout.json`;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
function getMarkdownPath(objectId: string, pageNumber: number) {
|
|
155
|
-
return `${getBasePath(objectId)}/pages/page-${pageNumber}.md`;
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
export function getResourceUrl(
|
|
159
|
-
vertesia: VertesiaClient,
|
|
160
|
-
objectId: string,
|
|
161
|
-
name: string,
|
|
162
|
-
): Promise<string> {
|
|
163
|
-
return vertesia.files
|
|
164
|
-
.getDownloadUrl(`${getBasePath(objectId)}/${name}`)
|
|
165
|
-
.then((r) => r.url);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
function getImageUrlForPage(
|
|
169
|
-
vertesia: VertesiaClient,
|
|
170
|
-
objectId: string,
|
|
171
|
-
pageNumber: number,
|
|
172
|
-
): Promise<GetFileUrlResponse> {
|
|
173
|
-
return vertesia.files.getDownloadUrl(
|
|
174
|
-
getPageImagePath(objectId, pageNumber),
|
|
175
|
-
);
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
function getAnnotatedImageUrlForPage(
|
|
179
|
-
vertesia: VertesiaClient,
|
|
180
|
-
objectId: string,
|
|
181
|
-
pageNumber: number,
|
|
182
|
-
): Promise<GetFileUrlResponse> {
|
|
183
|
-
return vertesia.files.getDownloadUrl(
|
|
184
|
-
getPageAnnotatedImagePath(objectId, pageNumber),
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
function getInstrumentedImageUrlForPage(
|
|
189
|
-
vertesia: VertesiaClient,
|
|
190
|
-
objectId: string,
|
|
191
|
-
pageNumber: number,
|
|
192
|
-
): Promise<GetFileUrlResponse> {
|
|
193
|
-
return vertesia.files.getDownloadUrl(
|
|
194
|
-
getPageInstrumentedImagePath(objectId, pageNumber),
|
|
195
|
-
);
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
function getOriginalImageUrlForPage(
|
|
199
|
-
vertesia: VertesiaClient,
|
|
200
|
-
objectId: string,
|
|
201
|
-
pageNumber: number,
|
|
202
|
-
): Promise<GetFileUrlResponse> {
|
|
203
|
-
return vertesia.files.getDownloadUrl(
|
|
204
|
-
getPageOriginalImagePath(objectId, pageNumber),
|
|
205
|
-
);
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
function getLayoutUrlForPage(
|
|
209
|
-
vertesia: VertesiaClient,
|
|
210
|
-
objectId: string,
|
|
211
|
-
pageNumber: number,
|
|
212
|
-
): Promise<GetFileUrlResponse> {
|
|
213
|
-
return vertesia.files.getDownloadUrl(
|
|
214
|
-
getLayoutJsonPath(objectId, pageNumber),
|
|
215
|
-
);
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
function getMarkdownUrlForPage(
|
|
219
|
-
vertesia: VertesiaClient,
|
|
220
|
-
objectId: string,
|
|
221
|
-
pageNumber: number,
|
|
222
|
-
): Promise<GetFileUrlResponse> {
|
|
223
|
-
return vertesia.files.getDownloadUrl(
|
|
224
|
-
getMarkdownPath(objectId, pageNumber),
|
|
225
|
-
);
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
async function getPdfPagesInfo(
|
|
229
|
-
vertesia: VertesiaClient,
|
|
230
|
-
object: ContentObject,
|
|
231
|
-
page_count: number,
|
|
232
|
-
): Promise<PdfPagesInfo> {
|
|
233
|
-
const imageUrlPromises: Promise<GetFileUrlResponse>[] = [];
|
|
234
|
-
for (let i = 0; i < page_count; i++) {
|
|
235
|
-
imageUrlPromises.push(getImageUrlForPage(vertesia, object.id, i + 1));
|
|
236
|
-
}
|
|
237
|
-
const imageUrls = await Promise.all(imageUrlPromises);
|
|
238
|
-
|
|
239
|
-
const annotatedImageUrlPromises: Promise<GetFileUrlResponse>[] = [];
|
|
240
|
-
for (let i = 0; i < page_count; i++) {
|
|
241
|
-
annotatedImageUrlPromises.push(
|
|
242
|
-
getAnnotatedImageUrlForPage(vertesia, object.id, i + 1),
|
|
243
|
-
);
|
|
244
|
-
}
|
|
245
|
-
const annotatedImageUrls = await Promise.all(annotatedImageUrlPromises);
|
|
246
|
-
|
|
247
|
-
const instrumentedImageUrlPromises: Promise<GetFileUrlResponse>[] = [];
|
|
248
|
-
for (let i = 0; i < page_count; i++) {
|
|
249
|
-
instrumentedImageUrlPromises.push(
|
|
250
|
-
getInstrumentedImageUrlForPage(vertesia, object.id, i + 1),
|
|
251
|
-
);
|
|
252
|
-
}
|
|
253
|
-
const instrumentedImageUrls = await Promise.all(
|
|
254
|
-
instrumentedImageUrlPromises,
|
|
255
|
-
);
|
|
256
|
-
|
|
257
|
-
const originalImageUrlPromises: Promise<GetFileUrlResponse>[] = [];
|
|
258
|
-
for (let i = 0; i < page_count; i++) {
|
|
259
|
-
originalImageUrlPromises.push(
|
|
260
|
-
getOriginalImageUrlForPage(vertesia, object.id, i + 1),
|
|
261
|
-
);
|
|
262
|
-
}
|
|
263
|
-
const originalImageUrls = await Promise.all(originalImageUrlPromises);
|
|
264
|
-
|
|
265
|
-
const layoutProvider = new PageLayoutProvider(page_count);
|
|
266
|
-
await layoutProvider.loadUrls(vertesia, object.id);
|
|
267
|
-
|
|
268
|
-
const markdownProvider = new PageMarkdownProvider(page_count);
|
|
269
|
-
await markdownProvider.loadUrls(vertesia, object.id);
|
|
270
|
-
|
|
271
|
-
const xml = object.text ? cleanXml(object.text) : "";
|
|
272
|
-
|
|
273
|
-
return {
|
|
274
|
-
count: page_count,
|
|
275
|
-
urls: imageUrls.map((r) => r.url),
|
|
276
|
-
originalUrls: originalImageUrls.map((r) => r.url),
|
|
277
|
-
annotatedUrls: annotatedImageUrls.map((r) => r.url),
|
|
278
|
-
instrumentedUrls: instrumentedImageUrls.map((r) => r.url),
|
|
279
|
-
layoutProvider,
|
|
280
|
-
markdownProvider,
|
|
281
|
-
xml,
|
|
282
|
-
xmlPages: object.text ? extractXmlPages(xml) : [],
|
|
283
|
-
};
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
export function usePdfPagesInfo() {
|
|
287
|
-
const context = React.useContext(PdfPageContext);
|
|
288
|
-
if (!context) {
|
|
289
|
-
throw new Error(
|
|
290
|
-
"usePdfPagesInfo must be used within a PdfPageProvider",
|
|
291
|
-
);
|
|
292
|
-
}
|
|
293
|
-
return context;
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
function extractXmlPages(xml: string): string[] {
|
|
297
|
-
// Parse the XML string
|
|
298
|
-
const doc = new DOMParser().parseFromString(cleanXml(xml), "text/xml");
|
|
299
|
-
const pages = doc.getElementsByTagName("page");
|
|
300
|
-
const serializer = new XMLSerializer();
|
|
301
|
-
return Array.from(pages).map((p) => serializer.serializeToString(p));
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
function cleanXml(xml: string) {
|
|
305
|
-
const cleanedXML = xml
|
|
306
|
-
// eslint-disable-next-line no-control-regex
|
|
307
|
-
.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g, "")
|
|
308
|
-
.replace(/<\?xml.*?\?>/g, "");
|
|
309
|
-
return cleanedXML;
|
|
310
|
-
}
|
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import { JSONCode, Theme, XMLViewer, MarkdownRenderer } from '@vertesia/ui/widgets';
|
|
2
|
-
import { useEffect, useLayoutEffect, useState } from "react";
|
|
3
|
-
import { usePdfPagesInfo } from "./PdfPageProvider";
|
|
4
|
-
import { ViewType } from "./types";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const darkTheme: Theme = {
|
|
8
|
-
attributeKeyColor: '#FFD700',
|
|
9
|
-
attributeValueColor: '#FF4500',
|
|
10
|
-
tagColor: '#87CEFA',
|
|
11
|
-
textColor: '#00FF00',
|
|
12
|
-
separatorColor: '#FFD700',
|
|
13
|
-
commentColor: "#BEBEBE",
|
|
14
|
-
cdataColor: "#33CC66",
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
interface TextPageViewProps {
|
|
19
|
-
pageNumber: number;
|
|
20
|
-
viewType: ViewType;
|
|
21
|
-
}
|
|
22
|
-
export function TextPageView({ viewType, pageNumber }: TextPageViewProps) {
|
|
23
|
-
switch (viewType) {
|
|
24
|
-
case "json":
|
|
25
|
-
return <JsonPageLayoutView pageNumber={pageNumber} />;
|
|
26
|
-
case "markdown":
|
|
27
|
-
return <MarkdownPageView pageNumber={pageNumber} />;
|
|
28
|
-
default:
|
|
29
|
-
return <XmlPageView pageNumber={pageNumber} />;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
interface XmlPageViewProps {
|
|
34
|
-
pageNumber: number;
|
|
35
|
-
}
|
|
36
|
-
function XmlPageView({ pageNumber }: XmlPageViewProps) {
|
|
37
|
-
const [theme, setTheme] = useState<Theme>();
|
|
38
|
-
const { xmlPages: pages } = usePdfPagesInfo();
|
|
39
|
-
useLayoutEffect(() => {
|
|
40
|
-
const media = window.matchMedia('(prefers-color-scheme: dark)');
|
|
41
|
-
const onMediaChange = (event: MediaQueryListEvent) => {
|
|
42
|
-
setTheme(event.matches ? darkTheme : undefined);
|
|
43
|
-
};
|
|
44
|
-
media.addEventListener('change', onMediaChange);
|
|
45
|
-
media.matches && setTheme(darkTheme);
|
|
46
|
-
return () => {
|
|
47
|
-
media.removeEventListener('change', onMediaChange);
|
|
48
|
-
}
|
|
49
|
-
}, []);
|
|
50
|
-
return (
|
|
51
|
-
<div className="px-4 py-2">
|
|
52
|
-
<XMLViewer xml={pages[pageNumber - 1]} collapsible theme={theme} />
|
|
53
|
-
</div>
|
|
54
|
-
)
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
interface JsonPageLayoutViewProps {
|
|
58
|
-
pageNumber: number;
|
|
59
|
-
}
|
|
60
|
-
function JsonPageLayoutView({ pageNumber }: JsonPageLayoutViewProps) {
|
|
61
|
-
const [content, setContent] = useState<any>();
|
|
62
|
-
const { layoutProvider } = usePdfPagesInfo();
|
|
63
|
-
useEffect(() => {
|
|
64
|
-
layoutProvider.getPageLayout(pageNumber).then(content => setContent(content ? JSON.parse(content) : undefined)).catch(err => {
|
|
65
|
-
console.error(err);
|
|
66
|
-
setContent(undefined);
|
|
67
|
-
});
|
|
68
|
-
}, [pageNumber]);
|
|
69
|
-
return (
|
|
70
|
-
content && <JSONCode className="w-full" data={content} />
|
|
71
|
-
)
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
interface MarkdownPageViewProps {
|
|
75
|
-
pageNumber: number;
|
|
76
|
-
}
|
|
77
|
-
function MarkdownPageView({ pageNumber }: MarkdownPageViewProps) {
|
|
78
|
-
const [content, setContent] = useState<string>();
|
|
79
|
-
const { markdownProvider } = usePdfPagesInfo();
|
|
80
|
-
useEffect(() => {
|
|
81
|
-
markdownProvider.getPageMarkdown(pageNumber).then(setContent).catch((err: any) => {
|
|
82
|
-
console.error(err);
|
|
83
|
-
setContent(undefined);
|
|
84
|
-
});
|
|
85
|
-
}, [pageNumber]);
|
|
86
|
-
return (
|
|
87
|
-
<div className="px-4 py-2 prose prose-sm max-w-none dark:prose-invert">
|
|
88
|
-
{content ? <MarkdownRenderer>{content}</MarkdownRenderer> : <div>No markdown content available</div>}
|
|
89
|
-
</div>
|
|
90
|
-
)
|
|
91
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { RefObject, useEffect } from "react";
|
|
2
|
-
|
|
3
|
-
interface ResizeOnDragOptions {
|
|
4
|
-
handler: RefObject<HTMLElement | null | undefined>;
|
|
5
|
-
left: RefObject<HTMLElement | null | undefined>;
|
|
6
|
-
right: RefObject<HTMLElement | null | undefined>;
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export function useResizeEW(opts: ResizeOnDragOptions) {
|
|
10
|
-
|
|
11
|
-
useEffect(() => {
|
|
12
|
-
if (opts.handler.current && opts.left.current && opts.right.current) {
|
|
13
|
-
const handler = opts.handler.current;
|
|
14
|
-
const left = opts.left.current;
|
|
15
|
-
const right = opts.right.current;
|
|
16
|
-
const onMouseDown = (e: MouseEvent) => {
|
|
17
|
-
let x = e.clientX;
|
|
18
|
-
let baseLW = left.offsetWidth;
|
|
19
|
-
let baseRL = right.offsetLeft;
|
|
20
|
-
const onMouseMove = (e: MouseEvent) => {
|
|
21
|
-
const dx = e.clientX - x;
|
|
22
|
-
left.style.width = `${baseLW + dx}px`;
|
|
23
|
-
right.style.left = `${baseRL + dx}px`;
|
|
24
|
-
(e.target as HTMLDivElement).classList.add('resizing');
|
|
25
|
-
}
|
|
26
|
-
const onMouseUp = (e: MouseEvent) => {
|
|
27
|
-
(e.target as HTMLDivElement).classList.remove('resizing');
|
|
28
|
-
onMouseMove(e);
|
|
29
|
-
document.removeEventListener('mousemove', onMouseMove);
|
|
30
|
-
document.removeEventListener('mouseup', onMouseUp);
|
|
31
|
-
}
|
|
32
|
-
document.addEventListener('mousemove', onMouseMove);
|
|
33
|
-
document.addEventListener('mouseup', onMouseUp);
|
|
34
|
-
}
|
|
35
|
-
handler.addEventListener('mousedown', onMouseDown);
|
|
36
|
-
return () => {
|
|
37
|
-
handler.removeEventListener('mousedown', onMouseDown);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}, [opts.handler.current, opts.left.current, opts.right.current]);
|
|
41
|
-
|
|
42
|
-
}
|