f97f891d67
Full ASP.NET Core 10 Razor Pages app for آساد ابزار tool repair shop in Karaj, Iran (official DeWalt representative). Features: - Homepage, Services, DeWalt page, Shop (pagination + images) - 10 brand SEO pages (/brands/*) with rich Persian content + FAQ schema - Blog engine with admin management (/blog, /Admin/Blog) - Cart, Checkout, Contact (OpenStreetMap embed) - Admin panel: Products CRUD, Orders, Blog, Change Password - Jalali date formatting, product images, SiteData centralised contact - Docker + docker-compose with healthcheck - Gitea CI/CD via .gitea/workflows/ci-cd.yml (NuGet through Nexus mirror) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
37 lines
1.4 KiB
C#
37 lines
1.4 KiB
C#
using AsadiTools.Data;
|
|
using AsadiTools.Models;
|
|
using Microsoft.AspNetCore.Mvc.RazorPages;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace AsadiTools.Pages.Blog;
|
|
|
|
public class BlogIndexModel(AppDbContext db) : PageModel
|
|
{
|
|
public const int PageSize = 6;
|
|
public List<BlogPost> Posts { get; private set; } = [];
|
|
public int CurrentPage { get; private set; } = 1;
|
|
public int TotalPages { get; private set; }
|
|
public string? Tag { get; private set; }
|
|
|
|
public async Task OnGetAsync(string? tag, int page = 1)
|
|
{
|
|
Tag = tag;
|
|
|
|
var q = db.BlogPosts.Where(p => p.IsPublished);
|
|
if (!string.IsNullOrEmpty(tag))
|
|
q = q.Where(p => p.Tags != null && p.Tags.Contains(tag));
|
|
|
|
var total = await q.CountAsync();
|
|
TotalPages = (int)Math.Ceiling(total / (double)PageSize);
|
|
CurrentPage = Math.Clamp(page, 1, Math.Max(1, TotalPages));
|
|
|
|
Posts = await q.OrderByDescending(p => p.PublishedAt)
|
|
.Skip((CurrentPage - 1) * PageSize)
|
|
.Take(PageSize)
|
|
.ToListAsync();
|
|
|
|
ViewData["Title"] = "بلاگ آساد ابزار — راهنما و مقالات تعمیر ابزار";
|
|
ViewData["Description"] = "مقالات تخصصی تعمیر و نگهداری ابزار برقی. راهنمای خرید، نکات فنی و اخبار صنعت ابزار از آساد ابزار کرج.";
|
|
}
|
|
}
|