summaryrefslogtreecommitdiffstats
path: root/assets
diff options
context:
space:
mode:
Diffstat (limited to 'assets')
-rw-r--r--assets/js/filters.js28
1 files changed, 28 insertions, 0 deletions
diff --git a/assets/js/filters.js b/assets/js/filters.js
new file mode 100644
index 0000000..64d9c57
--- /dev/null
+++ b/assets/js/filters.js
@@ -0,0 +1,28 @@
+// filters.js
+(function() {
+ const filterBtns = document.querySelectorAll('.filter-btn');
+ const feedList = document.getElementById('articles-feed');
+ const cards = feedList ? feedList.querySelectorAll('.post-card') : [];
+
+ if (!filterBtns.length || !cards.length) return;
+
+ filterBtns.forEach(btn => {
+ btn.addEventListener('click', function() {
+ const filter = this.dataset.filter;
+
+ // Update active button
+ filterBtns.forEach(b => b.classList.remove('active'));
+ this.classList.add('active');
+
+ // Filter cards
+ cards.forEach(card => {
+ const cardType = card.querySelector('.post-type-badge')?.classList[1];
+ const matches = filter === 'all' || cardType === filter;
+ card.style.display = matches ? '' : 'none';
+ });
+
+ // Scroll to top
+ window.scrollTo({ top: 0, behavior: 'smooth' });
+ });
+ });
+})();