2014-11-04 07:34:54 +00:00
|
|
|
/* jslint node: true */
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
var View = require('./view.js').View;
|
|
|
|
var miscUtil = require('./misc_util.js');
|
|
|
|
var strUtil = require('./string_util.js');
|
|
|
|
var ansi = require('./ansi_term.js');
|
|
|
|
var util = require('util');
|
|
|
|
var assert = require('assert');
|
|
|
|
|
|
|
|
exports.TickerTextView = TickerTextView;
|
|
|
|
|
2014-11-05 06:50:42 +00:00
|
|
|
function TickerTextView(client, options) {
|
2014-11-04 07:34:54 +00:00
|
|
|
View.call(this, client, options);
|
|
|
|
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
this.text = this.options.text || '';
|
|
|
|
this.tickerStyle = this.options.tickerStyle || 'rightToLeft';
|
2014-11-05 06:50:42 +00:00
|
|
|
assert(this.tickerStyle in TickerTextView.TickerStyles);
|
2014-11-04 07:34:54 +00:00
|
|
|
|
|
|
|
// :TODO: Ticker |text| should have ANSI stripped before calculating any lengths/etc.
|
|
|
|
// strUtil.ansiTextLength(s)
|
|
|
|
// strUtil.pad(..., ignoreAnsi)
|
|
|
|
// strUtil.stylizeString(..., ignoreAnsi)
|
|
|
|
|
|
|
|
this.tickerState = {};
|
|
|
|
switch(this.tickerStyle) {
|
|
|
|
case 'rightToLeft' :
|
|
|
|
this.tickerState.pos = this.position.x + this.dimens.width;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
self.onTickerInterval = function() {
|
|
|
|
switch(self.tickerStyle) {
|
|
|
|
case 'rightToLeft' : self.updateRightToLeftTicker(); break;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
self.updateRightToLeftTicker = function() {
|
|
|
|
// if pos < start
|
|
|
|
// drawRemain()
|
|
|
|
// if pos + remain > end
|
|
|
|
// drawRemain(0, spaceFor)
|
|
|
|
// else
|
|
|
|
// drawString() + remainPading
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
util.inherits(TickerTextView, View);
|
|
|
|
|
|
|
|
TickerTextView.TickerStyles = {
|
|
|
|
leftToRight : 1,
|
|
|
|
rightToLeft : 2,
|
|
|
|
bounce : 3,
|
|
|
|
slamLeft : 4,
|
|
|
|
slamRight : 5,
|
|
|
|
slamBounce : 6,
|
|
|
|
decrypt : 7,
|
|
|
|
typewriter : 8,
|
|
|
|
};
|
|
|
|
Object.freeze(TickerTextView.TickerStyles);
|
|
|
|
|
|
|
|
/*
|
|
|
|
TickerTextView.TICKER_STYLES = [
|
|
|
|
'leftToRight',
|
|
|
|
'rightToLeft',
|
|
|
|
'bounce',
|
|
|
|
'slamLeft',
|
|
|
|
'slamRight',
|
|
|
|
'slamBounce',
|
|
|
|
'decrypt',
|
|
|
|
'typewriter',
|
|
|
|
];
|
|
|
|
*/
|
|
|
|
|
|
|
|
TickerTextView.prototype.controllerAttached = function() {
|
|
|
|
// :TODO: call super
|
|
|
|
};
|
|
|
|
|
|
|
|
TickerTextView.prototype.controllerDetached = function() {
|
|
|
|
// :TODO: call super
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
TickerTextView.prototype.setText = function(text) {
|
|
|
|
this.text = strUtil.stylizeString(text, this.textStyle);
|
|
|
|
|
|
|
|
if(!this.dimens || !this.dimens.width) {
|
|
|
|
this.dimens.width = Math.ceil(this.text.length / 2);
|
|
|
|
}
|
|
|
|
};
|