<?php
/**
 * @link http://www.yiiframework.com/
 * @copyright Copyright (c) 2008 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 */

namespace frontend\widgets;

/**
 * Alert widget renders a message from session flash. All flash messages are displayed
 * in the sequence they were assigned using setFlash. You can set message as following:
 *
 * - \Yii::$app->getSession()->setFlash('error', 'This is the message');
 * - \Yii::$app->getSession()->setFlash('success', 'This is the message');
 * - \Yii::$app->getSession()->setFlash('info', 'This is the message');
 *
 * @author Kartik Visweswaran <kartikv2@gmail.com>
 * @author Alexander Makarov <sam@rmcerative.ru>
 */
class Alert extends \yii\bootstrap\Widget
{
	/**
	 * @var array the alert types configuration for the flash messages.
	 * This array is setup as $key => $value, where:
	 * - $key is the name of the session flash variable
	 * - $value is the bootstrap alert type (i.e. danger, success, info, warning)
	 */
	public $alertTypes = [
		'error'   => 'danger',
		'danger'  => 'danger',
		'success' => 'success',
		'info'    => 'info',
		'warning' => 'warning'
	];
	
	/**
	 * @var array the options for rendering the close button tag.
	 */
	public $closeButton = [];
	
	public function init()
	{
		parent::init();

		$session = \Yii::$app->getSession();
		$flashes = $session->getAllFlashes();
		$appendCss = isset($this->options['class']) ? ' ' . $this->options['class'] : '';
		
		foreach ($flashes as $type => $message) {
			/* initialize css class for each alert box */
			$this->options['class'] = 'alert-' . $this->alertTypes[$type] . $appendCss;

			/* assign unique id to each alert box */
			$this->options['id'] = $this->getId() . '-' . $type;

			echo \yii\bootstrap\Alert::widget([
				'body' => $message,
				'closeButton' => $this->closeButton,
				'options' => $this->options
			]);

			$session->removeFlash($type);
		}
	}
}