Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
83.33% covered (warning)
83.33%
5 / 6
80.00% covered (warning)
80.00%
4 / 5
CRAP
0.00% covered (danger)
0.00%
0 / 1
PromptToneRepository
83.33% covered (warning)
83.33%
5 / 6
80.00% covered (warning)
80.00%
4 / 5
5.12
0.00% covered (danger)
0.00%
0 / 1
 getAll
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 findById
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 create
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 update
100.00% covered (success)
100.00%
2 / 2
100.00% covered (success)
100.00%
1 / 1
1
 delete
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
1<?php
2
3namespace App\Http\Repositories;
4
5use App\Http\Models\PromptTone;
6use App\Http\Repositories\interfaces\IPromptToneRepository;
7use Illuminate\Support\Collection;
8
9/**
10 * Repository for prompt tone data access operations.
11 *
12 * Handles all database queries related to prompt tones,
13 * keeping data access logic separate from business logic.
14 */
15class PromptToneRepository implements IPromptToneRepository
16{
17    /**
18     * Get all prompt tones ordered by newest first.
19     *
20     * @return Collection<int, PromptTone> Collection of prompt tones
21     */
22    public function getAll(): Collection
23    {
24        return PromptTone::query()->orderBy('created_at', 'desc')->get();
25    }
26
27    /**
28     * Find a prompt tone by its ID.
29     *
30     * @param  string  $id  The prompt tone ID
31     * @return PromptTone|null The prompt tone or null if not found
32     */
33    public function findById(string $id): ?PromptTone
34    {
35        return PromptTone::find($id);
36    }
37
38    /**
39     * Create a new prompt tone.
40     *
41     * @param  array  $data  The prompt tone data
42     * @return PromptTone The created prompt tone
43     */
44    public function create(array $data): PromptTone
45    {
46        return PromptTone::create($data);
47    }
48
49    /**
50     * Update an existing prompt tone.
51     *
52     * @param  PromptTone  $promptTone  The prompt tone to update
53     * @param  array  $data  The update data
54     * @return PromptTone The updated prompt tone
55     */
56    public function update(PromptTone $promptTone, array $data): PromptTone
57    {
58        $promptTone->update($data);
59
60        return $promptTone->fresh();
61    }
62
63    /**
64     * Delete a prompt tone.
65     *
66     * @param  PromptTone  $promptTone  The prompt tone to delete
67     * @return bool True if deleted successfully
68     */
69    public function delete(PromptTone $promptTone): bool
70    {
71        return $promptTone->delete();
72    }
73}