1
0
mirror of https://github.com/XFox111/my-website.git synced 2026-04-22 07:28:01 +03:00

feat: customized Clarity analytics

This commit is contained in:
2024-08-21 00:23:50 +00:00
parent 67222999a9
commit 416e862959
3 changed files with 26 additions and 8 deletions
+15 -3
View File
@@ -5,7 +5,7 @@ import skills from "@/_data/skills";
import shared from "@/_styles/gallery.module.scss";
import { ArrowDownload24Regular } from "@fluentui/react-icons";
import Image from "next/image";
import React, { useId, useState } from "react";
import React, { useCallback, useId, useState } from "react";
import cls from "./SkillsSection.module.scss";
import links from "@/_data/links";
@@ -14,6 +14,12 @@ const SkillsSection: React.FC = () =>
const [selection, setSelection] = useState<number>(0);
const illustrations = useId();
const select = useCallback((index: number) =>
{
setSelection(index);
window.clarity?.("set", "checked", "skills");
}, []);
return (
<section id="skills" className={ cls.section }>
<div id={ illustrations } className={ cls.illustrations } aria-live="polite" aria-atomic>
@@ -25,7 +31,13 @@ const SkillsSection: React.FC = () =>
{ selection === 4 &&
// [SPECIAL] It's a surprize tool that will help us later
<div role="button" aria-label="Click me" className={ cls.whatsThis } onClick={ () => window.open("https://www.youtube.com/watch?v=dQw4w9WgXcQ") } />
<div role="button" aria-label="Click me"
className={ cls.whatsThis }
onClick={ () =>
{
window.clarity?.("event", "ngguu");
window.open("https://www.youtube.com/watch?v=dQw4w9WgXcQ");
} } />
}
</div>
<div className={ `${shared.list} ${cls.list}` }>
@@ -35,7 +47,7 @@ const SkillsSection: React.FC = () =>
<Button key={ index } type="button" aria-current={ selection === index } aria-controls={ illustrations }
className={ shared.listItem } appearance={ selection === index ? "primary" : "secondary" }
data-selected={ selection === index }
onClick={ () => setSelection(index) }
onClick={ () => select(index) }
aria-label={ `${skill.title} skills. Associated stack: ${skill.description}` }
icon={ <skill.icon /> } >