@deepcitation/deepcitation-js 1.1.3 → 1.1.5

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/lib/index.d.ts CHANGED
@@ -10,7 +10,7 @@ export { isGeminiGarbage, cleanRepeatingLastSentence, } from "./parsing/parseWor
10
10
  export type { Citation, CitationStatus, VerifyCitationRequest, VerifyCitationResponse, OutputImageFormat, } from "./types/citation.js";
11
11
  export { DEFAULT_OUTPUT_IMAGE_FORMAT } from "./types/citation.js";
12
12
  export type { Verification } from "./types/verification.js";
13
- export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, deterministicIdFromVerification, } from "./types/verification.js";
13
+ export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, } from "./types/verification.js";
14
14
  export type { SearchState, SearchStatus, SearchMethod, SearchAttempt, } from "./types/search.js";
15
15
  export type { ScreenBox, PdfSpaceItem, IVertex } from "./types/boxes.js";
16
16
  export { sha1Hash } from "./utils/sha.js";
package/lib/index.js CHANGED
@@ -9,7 +9,7 @@ export { parseCitation, getCitationStatus, getAllCitationsFromLlmOutput, groupCi
9
9
  export { normalizeCitations, getCitationPageNumber, } from "./parsing/normalizeCitation.js";
10
10
  export { isGeminiGarbage, cleanRepeatingLastSentence, } from "./parsing/parseWorkAround.js";
11
11
  export { DEFAULT_OUTPUT_IMAGE_FORMAT } from "./types/citation.js";
12
- export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, deterministicIdFromVerification, } from "./types/verification.js";
12
+ export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, } from "./types/verification.js";
13
13
  // Utilities
14
14
  export { sha1Hash } from "./utils/sha.js";
15
15
  export { generateCitationKey } from "./react/utils.js";
@@ -182,7 +182,7 @@ const DefaultPopoverContent = ({ verification, status, onImageClick, }) => {
182
182
  * This means partial matches have blue text (because they were found) but
183
183
  * an orange indicator (because they didn't match exactly).
184
184
  */
185
- export const CitationComponent = forwardRef(({ citation, children, className, displayCitationValue = false, fallbackDisplay, verification, variant = "brackets", eventHandlers, isMobile = false, renderIndicator, renderContent, popoverPosition = "top", renderPopoverContent, }, ref) => {
185
+ export const CitationComponent = forwardRef(({ citation, children, className, displayKeySpan = false, fallbackDisplay, verification, variant = "brackets", eventHandlers, isMobile = false, renderIndicator, renderContent, popoverPosition = "top", renderPopoverContent, }, ref) => {
186
186
  const containerRef = useRef(null);
187
187
  const wrapperRef = useRef(null);
188
188
  const [expandedImageSrc, setExpandedImageSrc] = useState(null);
@@ -274,13 +274,13 @@ export const CitationComponent = forwardRef(({ citation, children, className, di
274
274
  }
275
275
  // For text/minimal/brackets, show the value or fullPhrase
276
276
  return getCitationDisplayText(citation, {
277
- displayCitationValue: variant === "text" ||
277
+ displayKeySpan: variant === "text" ||
278
278
  variant === "minimal" ||
279
279
  variant === "brackets" ||
280
- displayCitationValue,
280
+ displayKeySpan,
281
281
  fallbackDisplay,
282
282
  });
283
- }, [citation, variant, displayCitationValue, fallbackDisplay]);
283
+ }, [citation, variant, displayKeySpan, fallbackDisplay]);
284
284
  // Found status class for text styling (blue for found, gray for miss)
285
285
  const foundStatusClass = useMemo(() => getFoundStatusClass(status), [status]);
286
286
  // Event handlers
@@ -300,7 +300,7 @@ export const CitationComponent = forwardRef(({ citation, children, className, di
300
300
  // Early return for miss with fallback display
301
301
  if (fallbackDisplay !== null &&
302
302
  fallbackDisplay !== undefined &&
303
- displayCitationValue &&
303
+ displayKeySpan &&
304
304
  isMiss) {
305
305
  return (_jsx("span", { className: classNames("dc-citation-fallback", className), children: fallbackDisplay }));
306
306
  }
@@ -332,9 +332,7 @@ export const CitationComponent = forwardRef(({ citation, children, className, di
332
332
  status,
333
333
  citationKey,
334
334
  displayText,
335
- isMergedDisplay: variant === "text" ||
336
- variant === "brackets" ||
337
- displayCitationValue,
335
+ isMergedDisplay: variant === "text" || variant === "brackets" || displayKeySpan,
338
336
  });
339
337
  }
340
338
  // Indicator-only variant - just the checkmark/warning
@@ -1,7 +1,7 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  import { memo, useMemo, useCallback, forwardRef, } from "react";
3
3
  import { getCitationStatus } from "../parsing/parseCitation.js";
4
- import { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationValueText, classNames, } from "./utils.js";
4
+ import { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationKeySpanText, classNames, } from "./utils.js";
5
5
  const TWO_DOTS_THINKING_CONTENT = "..";
6
6
  /**
7
7
  * Hook to get common citation data.
@@ -31,16 +31,16 @@ const DefaultPartialIndicator = () => (_jsx("span", { className: "citation-parti
31
31
  * <ChipCitation citation={citation} verification={found} size="md" />
32
32
  * ```
33
33
  */
34
- export const ChipCitation = forwardRef(({ citation, children, className, displayCitationValue = false, fallbackDisplay, verification, eventHandlers, isMobile = false, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), size = "md", showIcon = false, icon, }, ref) => {
34
+ export const ChipCitation = forwardRef(({ citation, children, className, displayKeySpan = false, fallbackDisplay, verification, eventHandlers, isMobile = false, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), size = "md", showIcon = false, icon, }, ref) => {
35
35
  const { citationKey, citationInstanceId, status } = useCitationData(citation, verification);
36
36
  const { isVerified, isMiss, isPartialMatch, isPending } = status;
37
37
  const displayText = useMemo(() => getCitationDisplayText(citation, {
38
- displayCitationValue,
38
+ displayKeySpan,
39
39
  fallbackDisplay,
40
- }), [citation, displayCitationValue, fallbackDisplay]);
41
- const valueText = useMemo(() => getCitationValueText(citation, {
42
- displayCitationValue,
43
- }), [citation, displayCitationValue]);
40
+ }), [citation, displayKeySpan, fallbackDisplay]);
41
+ const keySpanText = useMemo(() => getCitationKeySpanText(citation, {
42
+ displayKeySpan,
43
+ }), [citation, displayKeySpan]);
44
44
  const handleClick = useCallback((e) => {
45
45
  e.preventDefault();
46
46
  e.stopPropagation();
@@ -68,7 +68,7 @@ export const ChipCitation = forwardRef(({ citation, children, className, display
68
68
  ? "citation-chip--pending"
69
69
  : "";
70
70
  return (_jsxs(_Fragment, { children: [children, _jsxs("span", { ref: ref, "data-citation-id": citationKey, "data-citation-instance": citationInstanceId, "data-variant": "chip", className: classNames("citation-chip", sizeClasses[size], statusClass, className), onMouseEnter: preventTooltips ? undefined : handleMouseEnter, onMouseLeave: preventTooltips ? undefined : handleMouseLeave, onMouseDown: handleClick, onClick: (e) => e.stopPropagation(), "aria-label": displayText ? `Citation: ${displayText}` : undefined, children: [showIcon &&
71
- (icon || _jsx("span", { className: "citation-chip__icon", children: "\uD83D\uDCC4" })), valueText && !displayCitationValue && (_jsx("span", { className: "citation-chip__value", children: valueText })), _jsx("span", { className: "citation-chip__text", children: displayText }), isPartialMatch && renderPartialIndicator(status), isVerified && !isPartialMatch && renderVerifiedIndicator(status), isPending && (_jsx("span", { className: "citation-chip__pending", children: pendingContent }))] })] }));
71
+ (icon || _jsx("span", { className: "citation-chip__icon", children: "\uD83D\uDCC4" })), keySpanText && !displayKeySpan && (_jsx("span", { className: "citation-chip__keySpan", children: keySpanText })), _jsx("span", { className: "citation-chip__text", children: displayText }), isPartialMatch && renderPartialIndicator(status), isVerified && !isPartialMatch && renderVerifiedIndicator(status), isPending && (_jsx("span", { className: "citation-chip__pending", children: pendingContent }))] })] }));
72
72
  });
73
73
  ChipCitation.displayName = "ChipCitation";
74
74
  /**
@@ -81,13 +81,13 @@ ChipCitation.displayName = "ChipCitation";
81
81
  * // Renders: Text content¹
82
82
  * ```
83
83
  */
84
- export const SuperscriptCitation = forwardRef(({ citation, children, className, displayCitationValue = false, fallbackDisplay, verification, eventHandlers, isMobile = false, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), showBrackets = false, }, ref) => {
84
+ export const SuperscriptCitation = forwardRef(({ citation, children, className, displayKeySpan = false, fallbackDisplay, verification, eventHandlers, isMobile = false, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), showBrackets = false, }, ref) => {
85
85
  const { citationKey, citationInstanceId, status } = useCitationData(citation, verification);
86
86
  const { isVerified, isMiss, isPartialMatch, isPending } = status;
87
87
  const displayText = useMemo(() => getCitationDisplayText(citation, {
88
- displayCitationValue,
88
+ displayKeySpan,
89
89
  fallbackDisplay,
90
- }), [citation, displayCitationValue, fallbackDisplay]);
90
+ }), [citation, displayKeySpan, fallbackDisplay]);
91
91
  const handleClick = useCallback((e) => {
92
92
  e.preventDefault();
93
93
  e.stopPropagation();
@@ -173,14 +173,14 @@ FootnoteCitation.displayName = "FootnoteCitation";
173
173
  * // Renders: "quoted text" with subtle underline
174
174
  * ```
175
175
  */
176
- export const InlineCitation = forwardRef(({ citation, children, className, displayCitationValue = true, // Default to merged for inline
176
+ export const InlineCitation = forwardRef(({ citation, children, className, displayKeySpan = true, // Default to merged for inline
177
177
  fallbackDisplay, verification, eventHandlers, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), underlineStyle = "dotted", }, ref) => {
178
178
  const { citationKey, citationInstanceId, status } = useCitationData(citation, verification);
179
179
  const { isVerified, isMiss, isPartialMatch, isPending } = status;
180
180
  const displayText = useMemo(() => getCitationDisplayText(citation, {
181
- displayCitationValue,
181
+ displayKeySpan,
182
182
  fallbackDisplay,
183
- }), [citation, displayCitationValue, fallbackDisplay]);
183
+ }), [citation, displayKeySpan, fallbackDisplay]);
184
184
  const handleClick = useCallback((e) => {
185
185
  e.preventDefault();
186
186
  e.stopPropagation();
@@ -216,13 +216,13 @@ InlineCitation.displayName = "InlineCitation";
216
216
  * // Renders: 1
217
217
  * ```
218
218
  */
219
- export const MinimalCitation = forwardRef(({ citation, children, className, displayCitationValue = false, fallbackDisplay, verification, eventHandlers, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), showStatusIndicator = true, }, ref) => {
219
+ export const MinimalCitation = forwardRef(({ citation, children, className, displayKeySpan = false, fallbackDisplay, verification, eventHandlers, preventTooltips = false, pendingContent = TWO_DOTS_THINKING_CONTENT, renderVerifiedIndicator = () => _jsx(DefaultVerifiedIndicator, {}), renderPartialIndicator = () => _jsx(DefaultPartialIndicator, {}), showStatusIndicator = true, }, ref) => {
220
220
  const { citationKey, citationInstanceId, status } = useCitationData(citation, verification);
221
221
  const { isVerified, isMiss, isPartialMatch, isPending } = status;
222
222
  const displayText = useMemo(() => getCitationDisplayText(citation, {
223
- displayCitationValue,
223
+ displayKeySpan,
224
224
  fallbackDisplay,
225
- }), [citation, displayCitationValue, fallbackDisplay]);
225
+ }), [citation, displayKeySpan, fallbackDisplay]);
226
226
  const handleClick = useCallback((e) => {
227
227
  e.preventDefault();
228
228
  e.stopPropagation();
@@ -11,6 +11,6 @@
11
11
  * @packageDocumentation
12
12
  */
13
13
  export type { CitationContentProps, CitationRenderProps, CitationTooltipProps, CitationStyles, CitationStateClasses, CitationCursorClasses, CitationEventHandlers, CitationVariant as CitationVariantType, UrlFetchStatus, UrlCitationMeta, UrlCitationProps, } from "./types.js";
14
- export { extractDomain, isBlockedStatus, isErrorStatus, isVerifiedStatus } from "./UrlCitationComponent.js";
15
- export { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationValueText, classNames, CITATION_X_PADDING, CITATION_Y_PADDING, } from "./utils.js";
14
+ export { extractDomain, isBlockedStatus, isErrorStatus, isVerifiedStatus, } from "./UrlCitationComponent.js";
15
+ export { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationKeySpanText, classNames, CITATION_X_PADDING, CITATION_Y_PADDING, } from "./utils.js";
16
16
  export { CitationComponent, MemoizedCitationComponent, type CitationVariant, type CitationComponentProps, } from "./CitationComponent.js";
@@ -11,8 +11,8 @@
11
11
  * @packageDocumentation
12
12
  */
13
13
  // URL Utilities - For handling URL citation metadata
14
- export { extractDomain, isBlockedStatus, isErrorStatus, isVerifiedStatus } from "./UrlCitationComponent.js";
14
+ export { extractDomain, isBlockedStatus, isErrorStatus, isVerifiedStatus, } from "./UrlCitationComponent.js";
15
15
  // Utilities - For generating citation keys and display text
16
- export { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationValueText, classNames, CITATION_X_PADDING, CITATION_Y_PADDING, } from "./utils.js";
16
+ export { generateCitationKey, generateCitationInstanceId, getCitationDisplayText, getCitationKeySpanText, classNames, CITATION_X_PADDING, CITATION_Y_PADDING, } from "./utils.js";
17
17
  // Components
18
18
  export { CitationComponent, MemoizedCitationComponent, } from "./CitationComponent.js";
@@ -14,7 +14,7 @@ interface CitationContextValue {
14
14
  verification: Verification | null;
15
15
  searchState: SearchState | null;
16
16
  config: {
17
- displayCitationValue: boolean;
17
+ displayKeySpan: boolean;
18
18
  fallbackDisplay: string | null;
19
19
  pendingContent: ReactNode;
20
20
  };
@@ -28,7 +28,7 @@ export interface CitationRootProps {
28
28
  verification?: Verification | null;
29
29
  searchState?: SearchState | null;
30
30
  children: ReactNode;
31
- displayCitationValue?: boolean;
31
+ displayKeySpan?: boolean;
32
32
  fallbackDisplay?: string | null;
33
33
  pendingContent?: ReactNode;
34
34
  }
@@ -20,7 +20,7 @@ export function useCitationContextSafe() {
20
20
  return useContext(CitationContext);
21
21
  }
22
22
  /** Root component that provides citation context to all child primitives. */
23
- export const CitationRoot = forwardRef(({ citation, verification = null, searchState = null, children, displayCitationValue = false, fallbackDisplay = null, pendingContent = "..", className, ...props }, ref) => {
23
+ export const CitationRoot = forwardRef(({ citation, verification = null, searchState = null, children, displayKeySpan = false, fallbackDisplay = null, pendingContent = "..", className, ...props }, ref) => {
24
24
  const citationKey = useMemo(() => generateCitationKey(citation), [citation]);
25
25
  const citationInstanceId = useMemo(() => generateCitationInstanceId(citationKey), [citationKey]);
26
26
  const status = getCitationStatus(verification);
@@ -32,7 +32,7 @@ export const CitationRoot = forwardRef(({ citation, verification = null, searchS
32
32
  verification,
33
33
  searchState,
34
34
  config: {
35
- displayCitationValue,
35
+ displayKeySpan,
36
36
  fallbackDisplay,
37
37
  pendingContent,
38
38
  },
@@ -43,7 +43,7 @@ export const CitationRoot = forwardRef(({ citation, verification = null, searchS
43
43
  status,
44
44
  verification,
45
45
  searchState,
46
- displayCitationValue,
46
+ displayKeySpan,
47
47
  fallbackDisplay,
48
48
  pendingContent,
49
49
  ]);
@@ -100,7 +100,7 @@ export const CitationNumber = forwardRef(({ className, number, ...props }, ref)
100
100
  const displayNumber = useMemo(() => {
101
101
  if (number !== undefined)
102
102
  return String(number);
103
- if (config.displayCitationValue) {
103
+ if (config.displayKeySpan) {
104
104
  return (citation.value ||
105
105
  citation.citationNumber?.toString() ||
106
106
  config.fallbackDisplay ||
@@ -120,7 +120,7 @@ export const CitationValue = forwardRef(({ className, value, separator = " ", ..
120
120
  const displayValue = useMemo(() => {
121
121
  if (value !== undefined)
122
122
  return value;
123
- if (config.displayCitationValue)
123
+ if (config.displayKeySpan)
124
124
  return "";
125
125
  return citation.value || "";
126
126
  }, [value, citation, config]);
@@ -90,7 +90,7 @@ export interface BaseCitationProps {
90
90
  /** Class name for controlling inner content width */
91
91
  innerWidthClassName?: string;
92
92
  /** When true, displays value/citationNumber merged in the bracket */
93
- displayCitationValue?: boolean;
93
+ displayKeySpan?: boolean;
94
94
  /** Fallback display text when citation value is empty */
95
95
  fallbackDisplay?: string | null;
96
96
  /** Display variant for the citation */
@@ -13,14 +13,14 @@ export declare function generateCitationInstanceId(citationKey: string): string;
13
13
  * Gets the display text for a citation based on configuration.
14
14
  */
15
15
  export declare function getCitationDisplayText(citation: Citation, options?: {
16
- displayCitationValue?: boolean;
16
+ displayKeySpan?: boolean;
17
17
  fallbackDisplay?: string | null;
18
18
  }): string;
19
19
  /**
20
- * Gets the value text to display before the citation bracket.
20
+ * Gets the keySpan text to display before the citation bracket.
21
21
  */
22
- export declare function getCitationValueText(citation: Citation, options?: {
23
- displayCitationValue?: boolean;
22
+ export declare function getCitationKeySpanText(citation: Citation, options?: {
23
+ displayKeySpan?: boolean;
24
24
  }): string;
25
25
  /**
26
26
  * Joins class names, filtering out falsy values.
@@ -9,7 +9,6 @@ export function generateCitationKey(citation) {
9
9
  citation.pageNumber?.toString() || "",
10
10
  citation.fullPhrase || "",
11
11
  citation.keySpan?.toString() || "",
12
- citation.value || "",
13
12
  citation.lineIds?.join(",") || "",
14
13
  citation.timestamps?.startTime || "",
15
14
  citation.timestamps?.endTime || "",
@@ -28,9 +27,9 @@ export function generateCitationInstanceId(citationKey) {
28
27
  * Gets the display text for a citation based on configuration.
29
28
  */
30
29
  export function getCitationDisplayText(citation, options = {}) {
31
- const { displayCitationValue = false, fallbackDisplay } = options;
32
- if (displayCitationValue) {
33
- return (citation.value ||
30
+ const { displayKeySpan = false, fallbackDisplay } = options;
31
+ if (displayKeySpan) {
32
+ return (citation.keySpan?.toString() ||
34
33
  citation.citationNumber?.toString() ||
35
34
  fallbackDisplay ||
36
35
  "");
@@ -38,14 +37,14 @@ export function getCitationDisplayText(citation, options = {}) {
38
37
  return citation.citationNumber?.toString() || "";
39
38
  }
40
39
  /**
41
- * Gets the value text to display before the citation bracket.
40
+ * Gets the keySpan text to display before the citation bracket.
42
41
  */
43
- export function getCitationValueText(citation, options = {}) {
44
- const { displayCitationValue = false } = options;
45
- if (displayCitationValue) {
42
+ export function getCitationKeySpanText(citation, options = {}) {
43
+ const { displayKeySpan = false } = options;
44
+ if (displayKeySpan) {
46
45
  return "";
47
46
  }
48
- return citation.value || "";
47
+ return citation.keySpan?.toString() || "";
49
48
  }
50
49
  /**
51
50
  * Joins class names, filtering out falsy values.
@@ -6,6 +6,6 @@
6
6
  export type { Citation, CitationStatus, VerifyCitationRequest, VerifyCitationResponse, OutputImageFormat, } from "./citation.js";
7
7
  export { DEFAULT_OUTPUT_IMAGE_FORMAT } from "./citation.js";
8
8
  export type { Verification } from "./verification.js";
9
- export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, deterministicIdFromVerification, } from "./verification.js";
9
+ export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, } from "./verification.js";
10
10
  export type { SearchState, SearchStatus } from "./search.js";
11
11
  export type { ScreenBox, PdfSpaceItem, IVertex } from "./boxes.js";
@@ -4,4 +4,4 @@
4
4
  * @packageDocumentation
5
5
  */
6
6
  export { DEFAULT_OUTPUT_IMAGE_FORMAT } from "./citation.js";
7
- export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, deterministicIdFromVerification, } from "./verification.js";
7
+ export { NOT_FOUND_VERIFICATION_INDEX, PENDING_VERIFICATION_INDEX, BLANK_VERIFICATION, } from "./verification.js";
@@ -4,12 +4,9 @@ import { type PdfSpaceItem } from "./boxes.js";
4
4
  export declare const NOT_FOUND_VERIFICATION_INDEX = -1;
5
5
  export declare const PENDING_VERIFICATION_INDEX = -2;
6
6
  export declare const BLANK_VERIFICATION: Verification;
7
- export declare function deterministicIdFromVerification(verification: Verification): string;
8
7
  export interface Verification {
9
- regex?: RegExp | null;
10
- lowerCaseSearchTerm: string | null;
8
+ fileId?: string | null;
11
9
  label?: string | null;
12
- attachmentId?: string | null;
13
10
  pageNumber?: number | null;
14
11
  timestamp?: number | null;
15
12
  citation?: Citation;
@@ -1,11 +1,8 @@
1
- import { sha1Hash } from "../utils/sha.js";
2
1
  export const NOT_FOUND_VERIFICATION_INDEX = -1;
3
2
  export const PENDING_VERIFICATION_INDEX = -2;
4
3
  export const BLANK_VERIFICATION = {
4
+ fileId: null,
5
5
  pageNumber: NOT_FOUND_VERIFICATION_INDEX,
6
- regex: null,
7
- lowerCaseSearchTerm: null,
8
- attachmentId: null,
9
6
  matchSnippet: null,
10
7
  source: null,
11
8
  citation: {
@@ -18,6 +15,3 @@ export const BLANK_VERIFICATION = {
18
15
  pageNumber: NOT_FOUND_VERIFICATION_INDEX,
19
16
  },
20
17
  };
21
- export function deterministicIdFromVerification(verification) {
22
- return sha1Hash(`${verification.lowerCaseSearchTerm}-${verification.attachmentId}-${verification.pageNumber}-${verification.hitIndexWithinPage}-${verification.matchSnippet}-${verification?.hitIndexWithinPage}`);
23
- }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@deepcitation/deepcitation-js",
3
- "version": "1.1.3",
3
+ "version": "1.1.5",
4
4
  "description": "DeepCitation JavaScript SDK for deterministic AI citation verification",
5
5
  "type": "module",
6
6
  "private": false,