2 'libs/text!./templates/main.html',
\r 
   3 'libs/text!./templates/handle.html',
\r 
   4 'libs/underscore-min',
\r 
   6 ], function(mainTemplate, handleTemplate, _, Backbone) {
\r 
   9     var View = Backbone.View.extend({
\r 
  10         className: 'rng-view-tabs',
\r 
  13             'click ul a, i': '_onTabTitleClicked'
\r 
  16         initialize: function(options) {
\r 
  17             this.options = options || {};
\r 
  18             this.template = _.template(mainTemplate),
\r 
  19             this.handleTemplate = _.template(handleTemplate);
\r 
  21             this.selectedTab = null;
\r 
  24         render: function() {
\r 
  25             this.$el.html(this.template());
\r 
  27                 tabBar: this.$('.rng-view-tabs-tabBar'),
\r 
  28                 content: this.$('.rng-view-tabs-content')
\r 
  31             if(this.options.stacked) {
\r 
  32                 this.nodes.tabBar.addClass('nav-stacked nav-pills');
\r 
  36         addTab: function(title, slug, content) {
\r 
  37             if(this.contents[slug])
\r 
  39             this.contents[slug] = content;
\r 
  41             var text = (typeof title === 'string') ? title : (title.text || '');
\r 
  42             var icon = title.icon || null;
\r 
  44             this.nodes.tabBar.append(this.handleTemplate({text: text, icon: icon, slug: slug}));
\r 
  45             if(!this.selectedTab)
\r 
  46                 this.selectTab(slug);
\r 
  49         selectTab: function(slug) {
\r 
  50             if(slug !== this.selectedTab && this.contents[slug]) {
\r 
  51                 this.trigger('leaving', this.selectedTab);
\r 
  53                 if(this.selectedTab)
\r 
  54                     this.contents[this.selectedTab].detach();
\r 
  55                 this.nodes.content.append(this.contents[slug]);
\r 
  56                 this.nodes.tabBar.find('.active').removeClass('active');
\r 
  57                 this.nodes.tabBar.find('a[href="#'+slug+'"]').parent().addClass('active');
\r 
  59                 this.selectedTab = slug;
\r 
  60                 this.trigger('tabSelected', slug);
\r 
  66         _onTabTitleClicked: function(e) {
\r 
  68             var target = $(e.target);
\r 
  70                 target = target.parent();
\r 
  71             var slug = target.attr('href').substr(1);
\r 
  72             this.selectTab(slug);
\r