You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			100 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
			
		
		
	
	
			100 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			JavaScript
		
	
(function() {
 | 
						|
  'use strict';
 | 
						|
  window.Whisper = window.Whisper || {};
 | 
						|
 | 
						|
  Whisper.TimestampView = Whisper.View.extend({
 | 
						|
    initialize: function(options) {
 | 
						|
      extension.windows.onClosed(this.clearTimeout.bind(this));
 | 
						|
    },
 | 
						|
    update: function() {
 | 
						|
      this.clearTimeout();
 | 
						|
      var millis_now = Date.now();
 | 
						|
      var millis = this.$el.data('timestamp');
 | 
						|
      if (millis === '') {
 | 
						|
        return;
 | 
						|
      }
 | 
						|
      if (millis >= millis_now) {
 | 
						|
        millis = millis_now;
 | 
						|
      }
 | 
						|
      var result = this.getRelativeTimeSpanString(millis);
 | 
						|
      this.$el.text(result);
 | 
						|
 | 
						|
      var timestamp = moment(millis);
 | 
						|
      this.$el.attr('title', timestamp.format('llll'));
 | 
						|
 | 
						|
      var millis_since = millis_now - millis;
 | 
						|
      if (this.delay) {
 | 
						|
        if (this.delay < 0) {
 | 
						|
          this.delay = 1000;
 | 
						|
        }
 | 
						|
        this.timeout = setTimeout(this.update.bind(this), this.delay);
 | 
						|
      }
 | 
						|
    },
 | 
						|
    clearTimeout: function() {
 | 
						|
      clearTimeout(this.timeout);
 | 
						|
    },
 | 
						|
    getRelativeTimeSpanString: function(timestamp_) {
 | 
						|
      // Convert to moment timestamp if it isn't already
 | 
						|
      var timestamp = moment(timestamp_),
 | 
						|
        now = moment(),
 | 
						|
        timediff = moment.duration(now - timestamp);
 | 
						|
 | 
						|
      if (timediff.years() > 0) {
 | 
						|
        this.delay = null;
 | 
						|
        return timestamp.format(this._format.y);
 | 
						|
      } else if (timediff.months() > 0 || timediff.days() > 6) {
 | 
						|
        this.delay = null;
 | 
						|
        return timestamp.format(this._format.M);
 | 
						|
      } else if (timediff.days() > 0) {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(timediff.days() + 1, 'd')
 | 
						|
          .diff(now);
 | 
						|
        return timestamp.format(this._format.d);
 | 
						|
      } else if (timediff.hours() > 1) {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(timediff.hours() + 1, 'h')
 | 
						|
          .diff(now);
 | 
						|
        return this.relativeTime(timediff.hours(), 'h');
 | 
						|
      } else if (timediff.hours() === 1) {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(timediff.hours() + 1, 'h')
 | 
						|
          .diff(now);
 | 
						|
        return this.relativeTime(timediff.hours(), 'h');
 | 
						|
      } else if (timediff.minutes() > 1) {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(timediff.minutes() + 1, 'm')
 | 
						|
          .diff(now);
 | 
						|
        return this.relativeTime(timediff.minutes(), 'm');
 | 
						|
      } else if (timediff.minutes() === 1) {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(timediff.minutes() + 1, 'm')
 | 
						|
          .diff(now);
 | 
						|
        return this.relativeTime(timediff.minutes(), 'm');
 | 
						|
      } else {
 | 
						|
        this.delay = moment(timestamp)
 | 
						|
          .add(1, 'm')
 | 
						|
          .diff(now);
 | 
						|
        return this.relativeTime(timediff.seconds(), 's');
 | 
						|
      }
 | 
						|
    },
 | 
						|
    relativeTime: function(number, string) {
 | 
						|
      return moment.duration(number, string).humanize();
 | 
						|
    },
 | 
						|
    _format: {
 | 
						|
      y: 'll',
 | 
						|
      M: i18n('timestampFormat_M') || 'MMM D',
 | 
						|
      d: 'ddd',
 | 
						|
    },
 | 
						|
  });
 | 
						|
  Whisper.ExtendedTimestampView = Whisper.TimestampView.extend({
 | 
						|
    relativeTime: function(number, string, isFuture) {
 | 
						|
      return moment.duration(-1 * number, string).humanize(string !== 's');
 | 
						|
    },
 | 
						|
    _format: {
 | 
						|
      y: 'lll',
 | 
						|
      M: (i18n('timestampFormat_M') || 'MMM D') + ' LT',
 | 
						|
      d: 'ddd LT',
 | 
						|
    },
 | 
						|
  });
 | 
						|
})();
 |