mirror of
				https://github.com/beestat/app.git
				synced 2025-10-26 07:42:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * Green banner asking people for money. $_$
 | |
|  */
 | |
| beestat.component.card.contribute_reminder = function() {
 | |
|   var self = this;
 | |
| 
 | |
|   beestat.dispatcher.addEventListener([
 | |
|     'cache.user',
 | |
|     'setting.contribute_reminder_hide_until'
 | |
|   ], function() {
 | |
|     self.rerender();
 | |
|   });
 | |
| 
 | |
|   beestat.component.card.apply(this, arguments);
 | |
| };
 | |
| beestat.extend(beestat.component.card.contribute_reminder, beestat.component.card);
 | |
| 
 | |
| beestat.component.card.contribute_reminder.prototype.decorate_contents_ = function(parent) {
 | |
|   var self = this;
 | |
| 
 | |
|   // Don't render anything if the user is an active Patron.
 | |
|   if (beestat.component.card.contribute_reminder.should_show() === false) {
 | |
|     window.setTimeout(function() {
 | |
|       self.dispose();
 | |
|     }, 0);
 | |
|     return;
 | |
|   }
 | |
| 
 | |
|   parent.style('background', beestat.style.color.green.base);
 | |
| 
 | |
|   new beestat.component.tile()
 | |
|     .set_icon('heart')
 | |
|     .set_size('large')
 | |
|     .set_text([
 | |
|       'Support this project!',
 | |
|       'Your contribution matters'
 | |
|     ])
 | |
|     .set_background_color(beestat.style.color.green.dark)
 | |
|     .set_background_hover_color(beestat.style.color.green.light)
 | |
|     .addEventListener('click', function() {
 | |
|       new beestat.layer.contribute().render();
 | |
|     })
 | |
|     .render(parent);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Get the title of the card.
 | |
|  *
 | |
|  * @return {string} The title.
 | |
|  */
 | |
| beestat.component.card.contribute_reminder.prototype.get_title_ = function() {
 | |
|   return 'Enjoy beestat?';
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Decorate the close button.
 | |
|  *
 | |
|  * @param {rocket.Elements} parent
 | |
|  */
 | |
| beestat.component.card.contribute_reminder.prototype.decorate_top_right_ = function(parent) {
 | |
|   new beestat.component.tile()
 | |
|     .set_type('pill')
 | |
|     .set_shadow(false)
 | |
|     .set_icon('close')
 | |
|     .set_text_color('#fff')
 | |
|     .set_background_hover_color(beestat.style.color.green.light)
 | |
|     .addEventListener('click', function() {
 | |
|       (new beestat.component.modal.enjoy_beestat()).render();
 | |
|     })
 | |
|     .render(parent);
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * Determine whether or not this card should be shown.
 | |
|  *
 | |
|  * @return {boolean} Whether or not to show the card.
 | |
|  */
 | |
| beestat.component.card.contribute_reminder.should_show = function() {
 | |
|   if (
 | |
|     beestat.user.contribution_is_active() === true ||
 | |
|     window.is_demo === true ||
 | |
|     (
 | |
|       beestat.setting('contribute_reminder_hide_until') !== undefined &&
 | |
|       moment.utc(beestat.setting('contribute_reminder_hide_until')).isAfter(moment.utc())
 | |
|     )
 | |
|   ) {
 | |
|     return false;
 | |
|   }
 | |
| 
 | |
|   return true;
 | |
| };
 |