interface interactive
This commit is contained in:
98
app/components/hooks/useTextParsing.ts
Normal file
98
app/components/hooks/useTextParsing.ts
Normal file
@@ -0,0 +1,98 @@
|
||||
import { useMemo } from "react";
|
||||
import { EntityMapping } from "@/app/config/entityLabels";
|
||||
|
||||
export interface Word {
|
||||
text: string;
|
||||
displayText: string;
|
||||
start: number;
|
||||
end: number;
|
||||
isEntity: boolean;
|
||||
entityType?: string;
|
||||
entityIndex?: number;
|
||||
mapping?: EntityMapping;
|
||||
}
|
||||
|
||||
export const useTextParsing = (
|
||||
text: string,
|
||||
entityMappings: EntityMapping[]
|
||||
) => {
|
||||
const words = useMemo((): Word[] => {
|
||||
const segments: Word[] = [];
|
||||
let currentIndex = 0;
|
||||
|
||||
const sortedMappings = [...entityMappings].sort(
|
||||
(a, b) => a.start - b.start // CORRECTION: utiliser 'start' au lieu de 'startIndex'
|
||||
);
|
||||
|
||||
sortedMappings.forEach((mapping, mappingIndex) => {
|
||||
if (currentIndex < mapping.start) {
|
||||
// CORRECTION: utiliser 'start'
|
||||
const beforeText = text.slice(currentIndex, mapping.start);
|
||||
const beforeWords = beforeText.split(/\s+/).filter(Boolean);
|
||||
|
||||
beforeWords.forEach((word) => {
|
||||
const wordStart = text.indexOf(word, currentIndex);
|
||||
const wordEnd = wordStart + word.length;
|
||||
|
||||
segments.push({
|
||||
text: word,
|
||||
displayText: word,
|
||||
start: wordStart,
|
||||
end: wordEnd,
|
||||
isEntity: false,
|
||||
});
|
||||
|
||||
currentIndex = wordEnd;
|
||||
});
|
||||
}
|
||||
|
||||
// Utiliser displayName au lieu de entity_type
|
||||
// Ligne 45 - Ajouter du debug
|
||||
console.log("useTextParsing - mapping:", {
|
||||
text: mapping.text,
|
||||
displayName: mapping.displayName,
|
||||
entity_type: mapping.entity_type,
|
||||
});
|
||||
|
||||
const anonymizedText =
|
||||
mapping.displayName || `[${mapping.entity_type.toUpperCase()}]`;
|
||||
|
||||
segments.push({
|
||||
text: mapping.text,
|
||||
displayText: anonymizedText,
|
||||
start: mapping.start,
|
||||
end: mapping.end,
|
||||
isEntity: true,
|
||||
entityType: mapping.entity_type,
|
||||
entityIndex: mappingIndex,
|
||||
mapping: mapping,
|
||||
});
|
||||
|
||||
currentIndex = mapping.end; // CORRECTION: utiliser 'end'
|
||||
});
|
||||
|
||||
if (currentIndex < text.length) {
|
||||
const remainingText = text.slice(currentIndex);
|
||||
const remainingWords = remainingText.split(/\s+/).filter(Boolean);
|
||||
|
||||
remainingWords.forEach((word) => {
|
||||
const wordStart = text.indexOf(word, currentIndex);
|
||||
const wordEnd = wordStart + word.length;
|
||||
|
||||
segments.push({
|
||||
text: word,
|
||||
displayText: word,
|
||||
start: wordStart,
|
||||
end: wordEnd,
|
||||
isEntity: false,
|
||||
});
|
||||
|
||||
currentIndex = wordEnd;
|
||||
});
|
||||
}
|
||||
|
||||
return segments;
|
||||
}, [text, entityMappings]);
|
||||
|
||||
return { words };
|
||||
};
|
||||
Reference in New Issue
Block a user