Ignore:
Timestamp:
06/24/26 16:51:52 (11 days ago)
Author:
kikisrbinoska <srbinoskakristina07@…>
Branches:
main
Children:
3ae4bab
Parents:
99c1e45
Message:

Fixed views count

File:
1 edited

Legend:

Unmodified
Added
Removed
  • chapterx-frontend/src/components/admin/PlatformStats.tsx

    r99c1e45 ra8f4a2d  
    11import React, { useEffect } from 'react'
    2 import { Users, BookOpen, Heart, MessageCircle } from 'lucide-react'
     2import { Users, BookOpen, Heart, MessageCircle, Eye } from 'lucide-react'
    33import { useAuthStore } from '../../store/authStore'
    44import { useStoryStore } from '../../store/storyStore'
     
    1212  const totalLikes = stories.reduce((acc, s) => acc + s.total_likes, 0)
    1313  const totalComments = stories.reduce((acc, s) => acc + s.total_comments, 0)
     14  const totalViews = stories.reduce((acc, s) => acc + s.total_views, 0)
    1415  const published = stories.filter(s => s.status === 'published').length
    1516
     
    1718    { icon: <Users size={24} className="text-blue-300" />, label: 'Total Users', value: allUsers.length, color: 'bg-blue-500/20', change: `${allUsers.filter(u => u.role === 'writer').length} writers` },
    1819    { icon: <BookOpen size={24} className="text-violet-300" />, label: 'Total Stories', value: stories.length, color: 'bg-violet-500/20', change: `${published} published` },
     20    { icon: <Eye size={24} className="text-cyan-300" />, label: 'Total Views', value: totalViews.toLocaleString(), color: 'bg-cyan-500/20', change: 'Chapter reads' },
    1921    { icon: <Heart size={24} className="text-rose-300" />, label: 'Total Likes', value: totalLikes.toLocaleString(), color: 'bg-rose-500/20', change: 'Across all stories' },
    2022    { icon: <MessageCircle size={24} className="text-emerald-300" />, label: 'Total Comments', value: totalComments.toLocaleString(), color: 'bg-emerald-500/20', change: 'Platform-wide' },
     
    2224
    2325  return (
    24     <div className="grid grid-cols-2 md:grid-cols-4 gap-4">
     26    <div className="grid grid-cols-2 md:grid-cols-3 lg:grid-cols-5 gap-4">
    2527      {stats.map(stat => (
    2628        <div key={stat.label} className="bg-slate-800 border border-slate-700 rounded-2xl p-6">
Note: See TracChangeset for help on using the changeset viewer.