You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

67 lines
1.1 KiB

  1. define([
  2. 'js/system/events',
  3. 'html!ui/templates/announcements/template',
  4. 'css!ui/templates/announcements/styles',
  5. 'html!ui/templates/announcements/templateLine'
  6. ], function (
  7. events,
  8. template,
  9. styles,
  10. templateLine
  11. ) {
  12. return {
  13. tpl: template,
  14. message: null,
  15. maxTtl: 160,
  16. postRender: function () {
  17. this.onEvent('onGetAnnouncement', this.onGetAnnouncement.bind(this));
  18. },
  19. onGetAnnouncement: function (e) {
  20. this.clearMessage();
  21. let container = this.find('.list');
  22. let html = templateLine
  23. .replace('$MSG$', e.msg);
  24. let el = $(html)
  25. .appendTo(container);
  26. if (e.type)
  27. el.addClass(e.type);
  28. if (e.zIndex)
  29. el.css('z-index', e.zIndex);
  30. if (e.top)
  31. el.css('margin-top', e.top);
  32. this.message = {
  33. ttl: this.maxTtl,
  34. el: el
  35. };
  36. },
  37. update: function () {
  38. let message = this.message;
  39. if (!message)
  40. return;
  41. message.ttl--;
  42. if (message.ttl <= 0)
  43. this.clearMessage();
  44. },
  45. clearMessage: function () {
  46. let message = this.message;
  47. if (!message)
  48. return;
  49. this.message = null;
  50. message.el.remove();
  51. }
  52. };
  53. });