alert.js 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. (function (Misago) {
  2. 'use strict';
  3. var ALERT_BASE_DISPLAY_TIME = 5 * 1000;
  4. var ALERT_LENGTH_FACTOR = 70;
  5. var ALERT_MAX_DISPLAY_TIME = 9 * 1000;
  6. var ALERT_HIDE_ANIMATION_LENGTH = 300;
  7. var Alert = function(_) {
  8. var self = this;
  9. this.type = '';
  10. this.message = null;
  11. this.isVisible = false;
  12. var show = function(type, message) {
  13. self.type = type;
  14. self.message = message;
  15. self.isVisible = true;
  16. var displayTime = ALERT_BASE_DISPLAY_TIME;
  17. displayTime += message.length * ALERT_LENGTH_FACTOR;
  18. if (displayTime > ALERT_MAX_DISPLAY_TIME) {
  19. displayTime = ALERT_MAX_DISPLAY_TIME;
  20. }
  21. _.runloop.runOnce(function () {
  22. m.startComputation();
  23. self.isVisible = false;
  24. m.endComputation();
  25. }, 'flash-message-hide', displayTime);
  26. };
  27. var set = function(type, message) {
  28. _.runloop.stop('flash-message-hide');
  29. _.runloop.stop('flash-message-show');
  30. if (self.isVisible) {
  31. self.isVisible = false;
  32. _.runloop.runOnce(function () {
  33. m.startComputation();
  34. show(type, message);
  35. m.endComputation();
  36. }, 'flash-message-show', ALERT_HIDE_ANIMATION_LENGTH);
  37. } else {
  38. show(type, message);
  39. }
  40. };
  41. this.info = function(message) {
  42. set('info', message);
  43. };
  44. this.success = function(message) {
  45. set('success', message);
  46. };
  47. this.warning = function(message) {
  48. set('warning', message);
  49. };
  50. this.error = function(message) {
  51. set('error', message);
  52. };
  53. };
  54. Misago.addService('alert', {
  55. factory: function(_) {
  56. return new Alert(_);
  57. }
  58. });
  59. }(Misago.prototype));