## Social Media Management System - Add SocialMediaLink database model with platform, URL, icon, and ordering - Create complete CRUD API endpoints for admin social media management - Implement admin social media management page with Material-UI DataGrid - Add "Social Media" menu item to admin navigation - Update footer to dynamically load and display enabled social media links - Support multiple platforms: Facebook, Twitter, Instagram, YouTube, LinkedIn, GitHub, TikTok - Include proper icon mapping and fallback handling ## Admin Pages Improvements - Replace broken TinyMCE editor with working WYSIWYG rich text editor - Create SimpleRichEditor component with toolbar for formatting - Fix admin authentication to use cookies instead of localStorage tokens - Update all admin API calls to use credentials: 'include' - Increase content editor height to 800px for better editing experience - Add Lexical editor component as alternative (not currently used) ## Footer Pages System - Create 8 comprehensive footer pages: About, Blog, Support, API Docs, Terms, Privacy, Cookies, GDPR - Implement dynamic footer link management with smart categorization - Separate Quick Links and Legal sections with automatic filtering - Remove duplicate hardcoded links and use database-driven system - All footer pages are fully written with professional content ## Database & Dependencies - Add uuid package for ID generation - Update Prisma schema with new SocialMediaLink model and relations - Seed default social media links for Facebook, Twitter, Instagram, YouTube - Add Lexical rich text editor packages (@lexical/react, etc.) ## Technical Improvements - Fix async params compatibility for Next.js 15 - Update MUI DataGrid deprecated props - Improve admin layout navigation structure - Add proper TypeScript interfaces for all new components - Implement proper error handling and user feedback 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
97 lines
2.5 KiB
TypeScript
97 lines
2.5 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server';
|
|
import { prisma } from '@/lib/db';
|
|
import { verifyAdminAuth } from '@/lib/admin-auth';
|
|
|
|
export async function GET(request: NextRequest) {
|
|
try {
|
|
const adminUser = await verifyAdminAuth(request);
|
|
if (!adminUser) {
|
|
return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
|
|
}
|
|
|
|
const socialMediaLinks = await prisma.socialMediaLink.findMany({
|
|
orderBy: { order: 'asc' },
|
|
include: {
|
|
creator: { select: { name: true, email: true } },
|
|
updater: { select: { name: true, email: true } }
|
|
}
|
|
});
|
|
|
|
return NextResponse.json({
|
|
success: true,
|
|
data: socialMediaLinks
|
|
});
|
|
} catch (error) {
|
|
console.error('Error fetching social media links:', error);
|
|
return NextResponse.json(
|
|
{ success: false, error: 'Failed to fetch social media links' },
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
}
|
|
|
|
export async function POST(request: NextRequest) {
|
|
try {
|
|
const adminUser = await verifyAdminAuth(request);
|
|
if (!adminUser) {
|
|
return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
|
|
}
|
|
|
|
const body = await request.json();
|
|
const {
|
|
platform,
|
|
name,
|
|
url,
|
|
icon,
|
|
isEnabled = true,
|
|
order = 0
|
|
} = body;
|
|
|
|
if (!platform || !name || !url || !icon) {
|
|
return NextResponse.json(
|
|
{ success: false, error: 'Platform, name, URL, and icon are required' },
|
|
{ status: 400 }
|
|
);
|
|
}
|
|
|
|
// Check if platform already exists
|
|
const existingLink = await prisma.socialMediaLink.findUnique({
|
|
where: { platform }
|
|
});
|
|
|
|
if (existingLink) {
|
|
return NextResponse.json(
|
|
{ success: false, error: 'A social media link for this platform already exists' },
|
|
{ status: 400 }
|
|
);
|
|
}
|
|
|
|
const socialMediaLink = await prisma.socialMediaLink.create({
|
|
data: {
|
|
platform,
|
|
name,
|
|
url,
|
|
icon,
|
|
isEnabled,
|
|
order,
|
|
createdBy: adminUser.id,
|
|
updatedBy: adminUser.id
|
|
},
|
|
include: {
|
|
creator: { select: { name: true, email: true } },
|
|
updater: { select: { name: true, email: true } }
|
|
}
|
|
});
|
|
|
|
return NextResponse.json({
|
|
success: true,
|
|
data: socialMediaLink
|
|
});
|
|
} catch (error) {
|
|
console.error('Error creating social media link:', error);
|
|
return NextResponse.json(
|
|
{ success: false, error: 'Failed to create social media link' },
|
|
{ status: 500 }
|
|
);
|
|
}
|
|
} |