Skip to content

Commit e970023

Browse files
committed
fix([DsfrSkipLink]): 🐛 Les liens d'évitement ne peuvent pas fonctionner avec les liens vers les paragraphes html (#)
Car Vue les utilise déjà pour le router. Il faut donc implémenter le saut de paragraphe "à la main" Fix: #481
1 parent 74e3c68 commit e970023

File tree

2 files changed

+22
-13
lines changed

2 files changed

+22
-13
lines changed

src/components/DsfrSkipLinks/DsfrSkipLinks.stories.js

Lines changed: 14 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -10,7 +10,7 @@ export default {
1010
},
1111
links: {
1212
control: 'object',
13-
description: 'Permet de passer le label du lien et l’ancre ciblée sous forme de tableau d’objets. Chaque objet aura 2 propriétés : `id` et `text`.',
13+
description: 'Permet de passer le label du lien et l’id de l’élément html ciblée sous forme de tableau d’objets. Chaque objet aura 2 propriétés : `id` et `text`.',
1414
},
1515
},
1616
}
@@ -27,31 +27,32 @@ export const LiensDEvitement = (args) => ({
2727
},
2828

2929
template: `
30-
<DsfrSkipLinks
31-
:links="links"
32-
/>
30+
<DsfrSkipLinks
31+
:links="links"
32+
/>
33+
<h2 id="what">Qu'est-ce que le Lorem Ipsum?</h2>
34+
<p>Le <strong>Lorem Ipsum</strong> est simplement du faux texte employé dans la composition et la mise en page avant impression. Le Lorem Ipsum est le faux texte standard de l'imprimerie depuis les années 1500, quand un imprimeur anonyme assembla ensemble des morceaux de texte pour réaliser un livre spécimen de polices de texte. Il n'a pas fait que survivre cinq siècles, mais s'est aussi adapté à la bureautique informatique, sans que son contenu n'en soit modifié. Il a été popularisé dans les années 1960 grâce à la vente de feuilles Letraset contenant des passages du Lorem Ipsum, et, plus récemment, par son inclusion dans des applications de mise en page de texte, comme Aldus PageMaker.</p>
35+
</div>
36+
<h2 id="why">Pourquoi l'utiliser?</h2>
37+
<p>On sait depuis longtemps que travailler avec du texte lisible et contenant du sens est source de distractions, et empêche de se concentrer sur la mise en page elle-même. L'avantage du Lorem Ipsum sur un texte générique comme 'Du texte. Du texte. Du texte.' est qu'il possède une distribution de lettres plus ou moins normale, et en tout cas comparable avec celle du français standard. De nombreuses suites logicielles de mise en page ou éditeurs de sites Web ont fait du Lorem Ipsum leur faux texte par défaut, et une recherche pour 'Lorem Ipsum' vous conduira vers de nombreux sites qui n'en sont encore qu'à leur phase de construction. Plusieurs versions sont apparues avec le temps, parfois par accident, souvent intentionnellement (histoire d'y rajouter de petits clins d'oeil, voire des phrases embarassantes).</p>
38+
</div>
3339
`,
3440

3541
mounted () {
3642
document.body.parentElement.setAttribute('data-fr-theme', this.dark ? 'dark' : 'light')
3743
},
38-
3944
})
4045

4146
LiensDEvitement.args = {
4247
dark: false,
4348
links: [
4449
{
45-
id: '#header',
46-
text: 'Allons au header',
47-
},
48-
{
49-
id: '#content',
50-
text: 'Allons au content',
50+
id: 'what',
51+
text: 'Allons à la question du pourquoi ?',
5152
},
5253
{
53-
id: '#footer',
54-
text: 'Allons au footer',
54+
id: 'why',
55+
text: 'Allons à la question du comment ?',
5556
},
5657
],
5758
}

src/components/DsfrSkipLinks/DsfrSkipLinks.vue

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,13 @@ export default defineComponent({
1010
required: true,
1111
},
1212
},
13+
methods: {
14+
scrollMeTo (elementId) {
15+
const element = document.getElementById(elementId)
16+
const top = element?.offsetTop
17+
window.scrollTo(0, top)
18+
},
19+
},
1320
})
1421
</script>
1522
@@ -28,6 +35,7 @@ export default defineComponent({
2835
<a
2936
class="fr-link"
3037
:href="`#${link.id}`"
38+
@click.prevent="scrollMeTo(link.id)"
3139
>{{ link.text }}</a>
3240
</li>
3341
</ul>

0 commit comments

Comments
 (0)