- Created `quick-replies.blade.php` for managing quick replies. - Added `settings.blade.php` for admin settings management. - Implemented `ticket-show.blade.php` to display ticket details. - Introduced `timeline-card.blade.php` component for displaying timeline information. Enhance quick reply management functionality - Developed `quick-reply-manager.blade.php` for creating and editing quick replies. - Integrated Livewire for dynamic interaction and validation. Implement settings page for AI configuration - Created `settings-page.blade.php` for managing AI settings, including prompts and provider instances. - Added functionality for managing models and embeddings. Add ticket show functionality with real-time updates - Implemented ticket details view with processing status and tool call logs. - Added support for displaying article suggestions and error messages. Create unit tests for AI classifier and domain info tool - Added `AIClassifierServiceTest.php` to validate AI classifier functionality. - Implemented `DomainInfoToolTest.php` for domain parameter validation. - Created `OxxaClientTest.php` to test API interactions and password hashing.
44 lines
1.0 KiB
PHP
44 lines
1.0 KiB
PHP
<?php
|
|
|
|
namespace App\Services;
|
|
|
|
use App\Models\AIDecision;
|
|
use App\Models\Article;
|
|
use App\Models\Feedback;
|
|
use App\Models\Ticket;
|
|
|
|
class AdminDashboardService
|
|
{
|
|
public function stats(): array
|
|
{
|
|
return [
|
|
'articles_count' => Article::query()->count(),
|
|
'tickets_count' => Ticket::query()->count(),
|
|
'decisions_count' => AIDecision::query()->count(),
|
|
'feedback_accuracy' => $this->feedbackAccuracy(),
|
|
];
|
|
}
|
|
|
|
public function recentTickets(int $limit = 10)
|
|
{
|
|
return Ticket::query()->latest()->limit($limit)->get();
|
|
}
|
|
|
|
public function recentDecisions(int $limit = 10)
|
|
{
|
|
return AIDecision::query()->with(['ticket', 'article'])->latest()->limit($limit)->get();
|
|
}
|
|
|
|
private function feedbackAccuracy(): ?float
|
|
{
|
|
$total = Feedback::query()->count();
|
|
if ($total === 0) {
|
|
return null;
|
|
}
|
|
|
|
$correct = Feedback::query()->where('is_correct', true)->count();
|
|
|
|
return round(($correct / $total) * 100, 2);
|
|
}
|
|
}
|