From 4a17f14ff90ecc7594dae62631e395faf5c634f8 Mon Sep 17 00:00:00 2001 From: strong Date: Sun, 10 Jul 2016 21:46:22 +0700 Subject: [PATCH] widget --- AlertAsset.php | 26 ++++++++++++++++++++++++++ FlashMessage.php | 8 ++++++-- README.md | 3 ++- composer.json | 40 ++++++++++++++++++++++------------------ web/alert.css | 13 +++++++++++++ web/alert.js | 33 +++++++++++++++++++++++++++++++++ 6 files changed, 102 insertions(+), 21 deletions(-) create mode 100644 AlertAsset.php create mode 100644 web/alert.css create mode 100644 web/alert.js diff --git a/AlertAsset.php b/AlertAsset.php new file mode 100644 index 0000000..657cf83 --- /dev/null +++ b/AlertAsset.php @@ -0,0 +1,26 @@ +getView(); + AlertAsset::register($view); + if (Yii::$app->session->getAllFlashes()) { + $this->registerJs('showMessage("' . implode('
', Yii::$app->session->getAllFlashes()) . '")'); + } } } diff --git a/README.md b/README.md index a57682a..e2b6991 100644 --- a/README.md +++ b/README.md @@ -28,4 +28,5 @@ Usage Once the extension is installed, simply use it in your code by : ```php -``` \ No newline at end of file + +``` \ No newline at end of file diff --git a/composer.json b/composer.json index b0d2aaa..6b03d73 100644 --- a/composer.json +++ b/composer.json @@ -1,21 +1,25 @@ { - "name": "stronglab/yii2-alert", - "description": "Yii2 Alert Message", - "type": "yii2-extension", - "keywords": ["yii2","extension"], - "license": "BSD-3-Clause", - "authors": [ - { - "name": "strong", - "email": "strong.barnaul@gmail.com" - } - ], - "require": { - "yiisoft/yii2": "*" - }, - "autoload": { - "psr-4": { - "stronglab\\alert\\": "" - } + "name": "stronglab/yii2-alert", + "description": "Yii2 Alert Message", + "type": "yii2-extension", + "keywords": [ + "yii2", + "extension" + ], + "license": "BSD-3-Clause", + "authors": [ + { + "name": "strong", + "email": "strong.barnaul@gmail.com" } + ], + "require": { + "yiisoft/yii2": "*", + "yiisoft/yii2-bootstrap": "*" + }, + "autoload": { + "psr-4": { + "stronglab\\alert\\": "" + } + } } diff --git a/web/alert.css b/web/alert.css new file mode 100644 index 0000000..2de256a --- /dev/null +++ b/web/alert.css @@ -0,0 +1,13 @@ +.flash-modal { + position: fixed; + top: 20px; + right: 30px; + z-index: 9999; + display: none; + width: 350px; + padding: 30px; + text-align: center; + border-radius: 4px; + border: 1px #9acfea solid; + font-size: 1.1em; +} \ No newline at end of file diff --git a/web/alert.js b/web/alert.js new file mode 100644 index 0000000..2eceb82 --- /dev/null +++ b/web/alert.js @@ -0,0 +1,33 @@ +$(".flash-modal").bind("contextmenu", function (e) { + e.preventDefault(); + $(this).fadeOut(420); +}); + +function showMessage(message, fade, type) { + fade = typeof fade !== "undefined" ? fade : 1; + type = typeof type !== "undefined" ? type : "alert-info"; + var obj = $(".flash-modal"); + obj.html("" + message + ""); + obj.addClass(type); + obj.stop().animate({opacity: "100"}); + obj.show(); + if (fade) { + messageBoxFadeOut(); + obj.mouseover( + function () { + if ($(this).is(":animated")) { + $(this).stop().animate({opacity: "100"}); + } + } + ); + obj.mouseleave(messageBoxFadeOut); + + } +} + +function messageBoxFadeOut() { + var obj = $(".flash-modal"); + obj.fadeOut(7000, function () { + obj.removeClass("alert-danger alert-success alert-info"); + }); +} \ No newline at end of file