File size: 2,239 Bytes
6afedde
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Plugin remark pour transformer les liens markdown contenant des citations en citations simples
// Transforme [@reference](url) en [@reference]
export default function remarkUnwrapCitationLinks() {
    return (tree) => {
        // Fonction helper pour extraire le contenu textuel d'un nœud
        const getTextContent = (node) => {
            if (!node) return '';
            if (node.type === 'text') return node.value || '';
            if (Array.isArray(node.children)) {
                return node.children.map(getTextContent).join('');
            }
            return '';
        };

        const visit = (node, parent) => {
            if (!node || typeof node !== 'object') return;

            // Parcourir les enfants d'abord (post-order traversal)
            const children = Array.isArray(node.children) ? node.children : [];
            for (let i = 0; i < children.length; i++) {
                const child = children[i];
                visit(child, node);
            }

            // Si c'est un nœud de type 'link', vérifier son contenu
            if (node.type === 'link' && parent && Array.isArray(parent.children)) {
                // Récupérer le contenu textuel du lien
                const textContent = getTextContent(node);

                // Debug
                console.log('🔍 Link trouvé:', {
                    text: textContent,
                    url: node.url,
                    matches: /^@\w+/.test(textContent.trim())
                });

                // Vérifier si c'est une citation (commence par @)
                if (textContent && /^@\w+/.test(textContent.trim())) {
                    // Trouver l'index du nœud dans son parent
                    const index = parent.children.indexOf(node);

                    if (index !== -1) {
                        console.log('✅ Transformation:', textContent);
                        // Remplacer le nœud link par un nœud text simple
                        parent.children[index] = {
                            type: 'text',
                            value: textContent.trim()
                        };
                    }
                }
            }
        };

        visit(tree, null);
    };
}