|
1 | 1 | export function scopeStyles(htmlString, prefix) { |
2 | | - // Trouve toutes les balises <style scoped>...</style> |
3 | 2 | return htmlString.replace( |
4 | 3 | /<style\s+[^>]*scoped[^>]*>([\s\S]*?)<\/style>/gi, |
5 | 4 | (match, css) => { |
6 | | - // Préfixe chaque sélecteur CSS avec le préfix choisi |
7 | | - const scopedCSS = css.replace(/(^|})([^@}]+)/g, (full, brace, rules) => { |
8 | | - const scopedRules = rules |
9 | | - .split(",") |
10 | | - .map((sel) => sel.trim()) |
11 | | - .filter(Boolean) |
12 | | - .map((sel) => { |
13 | | - // On évite de doubler le préfixe |
14 | | - if (sel.startsWith(`${prefix}`)) return sel; |
15 | | - return `${prefix} ${sel}`; |
16 | | - }) |
17 | | - .join(", "); |
18 | | - return `${brace} ${scopedRules}`; |
19 | | - }); |
20 | | - // On désactive l'effet typewriter pour la balise style |
| 5 | + // Nettoie le CSS et supprime les commentaires |
| 6 | + let cleanCSS = css.replace(/\/\*[\s\S]*?\*\//g, ""); |
| 7 | + |
| 8 | + // Extrait chaque bloc de règle CSS : sélecteur(s) { propriétés } |
| 9 | + const ruleRegex = /([^{}]+)\{([^{}]*)\}/g; |
| 10 | + |
| 11 | + const scopedCSS = cleanCSS.replace( |
| 12 | + ruleRegex, |
| 13 | + (fullMatch, selectors, properties) => { |
| 14 | + // Traite chaque sélecteur séparé par des virgules |
| 15 | + const scopedSelectors = selectors |
| 16 | + .split(",") |
| 17 | + .map((sel) => sel.trim()) |
| 18 | + .filter(Boolean) |
| 19 | + .map((sel) => { |
| 20 | + // Évite de doubler le préfixe |
| 21 | + if (sel.startsWith(prefix)) return sel; |
| 22 | + |
| 23 | + // Gère les @-rules (media queries, keyframes, etc.) |
| 24 | + if (sel.startsWith("@")) return sel; |
| 25 | + |
| 26 | + // Ajoute le préfixe |
| 27 | + // Si on a une règle sur le message lui-même, il ne faut pas considérer le sélecteur comme enfant du message, mais comme portant sur le message lui-même |
| 28 | + const sep = sel === ".message" ? "" : " "; |
| 29 | + return `${prefix}${sep}${sel}`; |
| 30 | + }) |
| 31 | + .join(", "); |
| 32 | + |
| 33 | + // Reconstruit la règle complète |
| 34 | + return `${scopedSelectors} { ${properties} }`; |
| 35 | + }, |
| 36 | + ); |
| 37 | + // On désactive l'effet typewriter pour la balise style avec \` |
21 | 38 | return `\\\`<style>${scopedCSS}</style>\\\``; |
22 | 39 | }, |
23 | 40 | ); |
|
0 commit comments