FlashHelper.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <?php
  2. App::uses('AppHelper', 'View/Helper');
  3. App::uses('FlashComponent', 'Tools.Controller/Component');
  4. App::uses('Hash', 'Utility');
  5. /**
  6. * Flash helper
  7. */
  8. class FlashHelper extends AppHelper {
  9. public $helpers = array('Session');
  10. /**
  11. * Display all flash messages.
  12. *
  13. * TODO: export div wrapping method (for static messaging on a page)
  14. *
  15. * @param array $types Types to output. Defaults to all if none are specified.
  16. * @return string HTML
  17. */
  18. public function flash(array $types = array()) {
  19. // Get the messages from the session
  20. $messages = (array)$this->Session->read('messages');
  21. $cMessages = (array)Configure::read('messages');
  22. if (!empty($cMessages)) {
  23. $messages = (array)Hash::merge($messages, $cMessages);
  24. }
  25. $html = '';
  26. if (!empty($messages)) {
  27. $html = '<div class="flash-messages flashMessages">';
  28. if ($types) {
  29. foreach ($types as $type) {
  30. // Add a div for each message using the type as the class.
  31. foreach ($messages as $messageType => $msgs) {
  32. if ($messageType !== $type) {
  33. continue;
  34. }
  35. foreach ((array)$msgs as $msg) {
  36. $html .= $this->_message($msg, $messageType);
  37. }
  38. }
  39. }
  40. } else {
  41. foreach ($messages as $messageType => $msgs) {
  42. foreach ((array)$msgs as $msg) {
  43. $html .= $this->_message($msg, $messageType);
  44. }
  45. }
  46. }
  47. $html .= '</div>';
  48. if ($types) {
  49. foreach ($types as $type) {
  50. CakeSession::delete('messages.' . $type);
  51. Configure::delete('messages.' . $type);
  52. }
  53. } else {
  54. CakeSession::delete('messages');
  55. Configure::delete('messages');
  56. }
  57. }
  58. return $html;
  59. }
  60. /**
  61. * Outputs a single flash message directly.
  62. * Note that this does not use the Session.
  63. *
  64. * @param string $message String to output.
  65. * @param string $type Type (success, warning, error, info)
  66. * @param bool $escape Set to false to disable escaping.
  67. * @return string HTML
  68. */
  69. public function message($msg, $type = 'info', $escape = true) {
  70. $html = '<div class="flash-messages flashMessages">';
  71. if ($escape) {
  72. $msg = h($msg);
  73. }
  74. $html .= $this->_message($msg, $type);
  75. $html .= '</div>';
  76. return $html;
  77. }
  78. /**
  79. * Formats a message
  80. *
  81. * @param string $msg Message to output.
  82. * @param string $type Type that will be formatted to a class tag.
  83. * @return string
  84. */
  85. protected function _message($msg, $type) {
  86. if (!empty($msg)) {
  87. return '<div class="message' . (!empty($type) ? ' ' . $type : '') . '">' . $msg . '</div>';
  88. }
  89. return '';
  90. }
  91. /**
  92. * Add a message on the fly
  93. *
  94. * @param string $msg
  95. * @param string $class
  96. * @return void
  97. */
  98. public function addTransientMessage($msg, $class = null) {
  99. FlashComponent::transientMessage($msg, $class);
  100. }
  101. /**
  102. * CommonHelper::transientFlashMessage()
  103. *
  104. * @param mixed $msg
  105. * @param mixed $class
  106. * @return void
  107. * @deprecated Use addFlashMessage() instead
  108. */
  109. public function transientFlashMessage($msg, $class = null) {
  110. $this->addFlashMessage($msg, $class);
  111. }
  112. }