2015-01-25 13:02:20 +01:00
|
|
|
define([
|
|
|
|
'knockout', 'text!./Tools.html'
|
|
|
|
], function(ko, htmlString) {
|
|
|
|
|
2015-02-19 10:12:09 +01:00
|
|
|
ko.components.register('Tools/Holding Pattern', {
|
|
|
|
require : 'topics/Tools/Holding'
|
|
|
|
});
|
|
|
|
|
2015-02-22 21:40:30 +01:00
|
|
|
ko.components.register('Tools/Vertical Navigation', {
|
|
|
|
require : 'topics/Tools/VerticalNavigation'
|
|
|
|
});
|
|
|
|
|
2015-02-18 12:31:00 +01:00
|
|
|
ko.components.register('Tools/Stopwatch', {
|
|
|
|
require : 'topics/Tools/Stopwatch'
|
|
|
|
});
|
|
|
|
|
2015-01-25 13:02:20 +01:00
|
|
|
function ViewModel(params) {
|
|
|
|
var self = this;
|
|
|
|
|
|
|
|
self.topics = [
|
|
|
|
'Holding Pattern',
|
|
|
|
'Wind Calculator',
|
|
|
|
'Vertical Navigation',
|
|
|
|
'Stopwatch'
|
|
|
|
];
|
|
|
|
|
|
|
|
self.selectedTopic = ko.observable();
|
|
|
|
|
|
|
|
self.selectedComponent = ko.pureComputed(function() {
|
|
|
|
return "Tools/" + self.selectedTopic();
|
|
|
|
});
|
|
|
|
|
|
|
|
self.selectTopic = function(topic) {
|
|
|
|
self.selectedTopic(topic);
|
|
|
|
}
|
|
|
|
|
|
|
|
self.selectTopic(self.topics[0]);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
ViewModel.prototype.dispose = function() {
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return component definition
|
|
|
|
return {
|
|
|
|
viewModel : ViewModel,
|
|
|
|
template : htmlString
|
|
|
|
};
|
|
|
|
});
|