วิธีการติดตั้ง Umami ใน Astro
วิธีการติดตั้ง Umami ลงบนเว็บไซต์ที่เขียนด้วย Astro จริงๆ การติดตั้งก็ง่ายมาก คือแค่เพิ่ม tracking code ลงไปในเว็บไซต์ แต่ในตัว Astro จะมีปัญหานิดหน่อย ถ้าเราใช้ View Transition หรือปัญหาฝั่ง client ก็คือกรณีที่ Browser บล็อคการเข้าถึง script หรือโดน adblock บล็อคนั่นเอง
การติดตั้ง Umami
วิธีการติดตั้งก็เข้าไปหน้า Settings ของ Umami Cloud แล้วนำ Tracking Code มาแปะไว้ที่หน้าเว็บของเรา เช่นใน <head>..</head>
ปัญหา adblock บล็อค
หากเรามี Adblocker หรือ browser มีการกำหนด privacy บางครั้งตัว browser จะทำการ block umami script ทำให้เราไม่สามารถ tracking ได้
วิธีการแก้ไขก็คือ มีได้หลายแบบ เช่น
host script เอง
ทำการ host ตัว script เอง ที่เว็บไซต์ของเรา คือ ปกติ เราจะ src ไปที่ https://cloud.umami.is/script.js
เราก็แค่สร้างไฟล์ .js
ของเราเอง สมมติ ผมตั้งชื่อว่า my-script.js
ขอเสียของวิธีนี้คือ ถ้าหากตัว umami มีการอัพเดท code เราก็ต้องทำการอัพเดทตามทุกครั้ง
proxy ด้วย Cloudflare worker
วิธีนี้คือการำ proxying ด้วยการใช้ Cloudlfare worker โดยผมทำการ custom script จากตัว Plausible ซึ่ง doc ก็อ่านเพิ่มเติมได้จาก link ด้านล่างนี้ครับ
ตัวอย่าง Cloudlare worker (เข้าจากหน้า cloudflare dashboard -> Workder & Pages)
ปัญหา Astro
ปัญหา เนื่องจากเว็บนี้ที่เขียนด้วย Astro ได้ใช้ View Transition ทำให้มันเกิด side-effect นิดหน่อย คือตัว tracking จะมองเห็นว่า user เปิดหน้าแรก (initial page) เท่านั้น แม้ว่าจะกดไปหน้าอื่นๆ ก็ตาม
วิธีแก้ไข คือใช้ data-astro-rerum
มาช่วย ค่านี้ จะ trigger ก็ต่อเมื่อมีการ reload page จริงๆ หลังจาก transition ซึ่งจะทำให้ analytics มัน tracking ตรงละ
🎉 เพียงเท่านี้ ก็สามารถ tracking ได้แล้ว
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust