https://packagist.org/packages/tamtamchik/simple-flash
Install
Via Composer.
$ composer require tamtamchik/simple-flash
Inside your project make sure to start a session and load Composer autoload to make everything work.
<?php // Start a Session if( !session_id() ) @session_start(); // Initialize Composer Autoload require_once 'vendor/autoload.php';
Warning! This library contains globalflash()
function, that potentially can break your function with this name. Now you are warned!
Usage
There are 3 ways to use library:
use \Tamtamchik\SimpleFlash\Flash; // Instance $flash = new Flash(); $flash->message('Tea.'); // Static Flash::message('Earl Gray.'); // Function flash()->message('Hot!');
Messages added by calling
message($message, $type = 'info')
method. In case of calling a function flash()
you can pass $message, $type
just to function like so:flash('resistance is futile')
.
Because any of creation types return
\Tamtamchik\SimpleFlash\Flash
instance, so you can always use chaining to add multiple messages. Shortcuts available for all types of base message types, also you can pass arrays as $message
.flash()->error(['Invalid email!', 'Invalid username!']) ->warning('Warning message.') ->info('Info message.') ->success('Success message!');
Out of the box library support 4 different types of messages:
error
, warning
, info
, success
. So far output is hard coded and designed for Bootstrap.<div class="alert alert-danger" role="alert"> <p>Invalid email!</p> <p>Invalid username!</p> </div> <div class="alert alert-warning" role="alert"><p>Warning message.</p></div> <div class="alert alert-info" role="alert"><p>Info message.</p></div> <div class="alert alert-success" role="alert"><p>Success message!</p></div>
Rendering is simple:
// Rendering specific type $output = flash()->display('error'); // Rendering all flash $output = flash()->display(); // Also rendering possible when you just read instance of \Tamtamchik\SimpleFlash\Flash object as a string (string) flash(); // or ... it's totally just for display, never do this in real life... <?php // ... some code $flash = new Flash(); $flash->warning('It is totally just for display, never do this in real life...'); // ... some other code ?> <!-- ... some html --> <div class="flashes"> <?= $flash; ?> </div> <!-- ... some other html -->
Templates
Template Factory
Package comes with a set of templates for most popular CSS frameworks. Bootstrap 3, Bootstrap 4, Foundation 5, Foundation 6, Semantic UI 2, UIKit 2.
This templates can be created using TemplateFactory that comes with package. All templates have aliases defined in Templates.
use Tamtamchik\SimpleFlash\Flash; use Tamtamchik\SimpleFlash\TemplateFactory; use Tamtamchik\SimpleFlash\Templates; // get template from factory, e.g. template for Foundation 6 $template = TemplateFactory::create(Templates::FOUNDATION_6); // passing template via function flash('Info message using Foundation 6 template!', 'info', $template); // passing to constructor $flash = new Flash($template); // using setTemplate function $flash->setTemplate($template);
Creating own templates
Template is basically any class that implements TemplateInterface. But to make it easy you can extend BaseTemplate, it contains most of the functions.
Defining and using this sample class as template:
use Tamtamchik\SimpleFlash\BaseTemplate; use Tamtamchik\SimpleFlash\TemplateInterface; class CustomTemplate extends BaseTemplate implements TemplateInterface { protected $prefix = '<li>'; // every line prefix protected $postfix = '</li>'; // every postfix protected $wrapper = '<ul class="alert-%s">%s</ul>'; // wrapper over messages of same type /** * @param $messages - message text * @param $type - message type: success, info, warning, error * * @return string */ public function wrapMessages($messages, $type) { return sprintf($this->getWrapper(), $type, $messages); } } flash() ->setTemplate(new CustomTemplate) ->error(['Invalid email!', 'Invalid username!']) ->warning('Warning message.') ->info('Info message.') ->success('Success message!') ->display();
Will output following:
<ul class="alert-error"> <li>Invalid email!</li> <li>Invalid username!</li> </ul> <ul class="alert-warning"> <li>Warning message.</li> </ul> <ul class="alert-info"> <li>Info message.</li> </ul> <ul class="alert-success"> <li>Success message!</li> </ul>
Comments
Post a Comment