2015-03-05 14:58:48 +01:00
|
|
|
define([
|
2015-03-10 22:44:20 +01:00
|
|
|
'knockout', 'text!./metar.html', 'fgcommand', 'kojqui/tooltip'
|
|
|
|
], function(ko, htmlString, fgCommand ) {
|
2015-03-05 14:58:48 +01:00
|
|
|
|
|
|
|
function ViewModel(params) {
|
2015-03-10 22:44:20 +01:00
|
|
|
var NO_METAR = "*** no METAR ";
|
2015-03-05 14:58:48 +01:00
|
|
|
self.scrolledMetar = ko.observable("");
|
|
|
|
self.textStart = 0;
|
|
|
|
self.metar = ko.observable(NO_METAR);
|
|
|
|
self.valid = ko.observable(false).extend({ fgprop: 'metar-valid' });
|
|
|
|
self.valid.subscribe(function(newValue) {
|
|
|
|
self.textStart = 0;
|
|
|
|
if( false == newValue ) {
|
|
|
|
self.metar(NO_METAR);
|
|
|
|
return;
|
|
|
|
}
|
2015-03-10 22:44:20 +01:00
|
|
|
self.metar("Wait.. ");
|
|
|
|
fgCommand.getPropertyValue('/environment/metar/data', function(value) {
|
2015-03-05 14:58:48 +01:00
|
|
|
self.textStart = 0;
|
2015-03-10 22:44:20 +01:00
|
|
|
// start with station id (4 upcase chars), skip leading garbage
|
|
|
|
var idx = value.search("[A-Z]{4}");
|
|
|
|
if( idx >= 0 ) value = value.substring(idx);
|
|
|
|
self.metar(value);
|
2015-03-05 14:58:48 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
self.textLength = 20;
|
2015-03-06 09:36:09 +01:00
|
|
|
self.timerId = 0;
|
|
|
|
self.longTimeout = 1500;
|
|
|
|
self.shortTimeout = 50;
|
|
|
|
|
|
|
|
function scrollText ( id ){
|
|
|
|
if( id != self.timerId )
|
|
|
|
return;
|
|
|
|
|
2015-03-05 14:58:48 +01:00
|
|
|
var t = self.metar() + " " + self.metar();
|
|
|
|
var a = self.textStart;
|
|
|
|
var b = a+self.textLength;
|
|
|
|
self.scrolledMetar( t.substring(a,b) );
|
2015-03-06 09:36:09 +01:00
|
|
|
var timeout = t.charAt(a) == ' ' ? self.longTimeout : self.shortTimeout;
|
2015-03-05 14:58:48 +01:00
|
|
|
if( ++a >= self.metar().length )
|
|
|
|
a = 0;
|
|
|
|
self.textStart = a;
|
2015-03-06 09:36:09 +01:00
|
|
|
setTimeout(function() { scrollText(id); }, timeout );
|
|
|
|
}
|
|
|
|
|
|
|
|
scrollText( ++self.timerId );
|
2015-03-05 14:58:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
ViewModel.prototype.dispose = function() {
|
2015-03-06 09:36:09 +01:00
|
|
|
self.timerId++;
|
2015-03-05 14:58:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Return component definition
|
|
|
|
return {
|
|
|
|
viewModel : ViewModel,
|
|
|
|
template : htmlString
|
|
|
|
};
|
|
|
|
});
|