-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfunctions.php
77 lines (71 loc) · 2.99 KB
/
functions.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
declare(strict_types=1);
namespace Flasher\Toastr\Prime;
use Flasher\Prime\Container\FlasherContainer;
use Flasher\Prime\Notification\Envelope;
use Flasher\Prime\Notification\Type;
if (!\function_exists('Flasher\Toastr\Prime\toastr')) {
/**
* Creates a Toastr notification or returns the Toastr factory.
*
* This function simplifies the process of creating Toastr notifications.
* When called with no arguments, it returns an instance of ToastrInterface.
* When called with arguments, it creates a Toastr notification and returns an Envelope.
*
* @param string|null $message the message content of the notification
* @param "success"|"info"|"warning"|"error" $type The type of the notification (e.g., success, error, warning, info).
* @param array{
* closeButton?: bool,
* closeClass?: string,
* closeDuration?: int,
* closeEasing?: string,
* closeHtml?: string,
* closeMethod?: string,
* closeOnHover?: bool,
* containerId?: string,
* debug?: bool,
* escapeHtml?: bool,
* extendedTimeOut?: int,
* hideDuration?: int,
* hideEasing?: string,
* hideMethod?: string,
* iconClass?: string,
* messageClass?: string,
* newestOnTop?: bool,
* onHidden?: string,
* onShown?: string,
* positionClass?: "toast-top-right"|"toast-top-center"|"toast-bottom-center"|"toast-top-full-width"|"toast-bottom-full-width"|"toast-top-left"|"toast-bottom-right"|"toast-bottom-left",
* preventDuplicates?: bool,
* progressBar?: bool,
* progressClass?: string,
* rtl?: bool,
* showDuration?: int,
* showEasing?: string,
* showMethod?: string,
* tapToDismiss?: bool,
* target?: string,
* timeOut?: int,
* titleClass?: string,
* toastClass?: string,
* } $options additional options for the Toastr notification
* @param string|null $title the title of the notification
*
* @return Envelope|ToastrInterface Returns an Envelope containing the notification details when arguments are provided.
* Returns an instance of ToastrInterface when no arguments are provided.
*
* @phpstan-return ($message is empty ? ToastrInterface : Envelope)
*
* Usage:
* 1. Without arguments - Get the Toastr factory: $toastr = toastr();
* 2. With arguments - Create and return a Toastr notification:
* toastr('Message', Type::SUCCESS, ['option' => 'value'], 'Title');
*/
function toastr(?string $message = null, string $type = Type::SUCCESS, array $options = [], ?string $title = null): Envelope|ToastrInterface
{
$factory = FlasherContainer::create('flasher.toastr');
if (0 === \func_num_args()) {
return $factory;
}
return $factory->flash($type, $message, $options, $title);
}
}