Skip to content

Instantly share code, notes, and snippets.

@mikeknoop
Created February 23, 2012 21:58
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mikeknoop/1895285 to your computer and use it in GitHub Desktop.
Save mikeknoop/1895285 to your computer and use it in GitHub Desktop.
Backbone Chrome Extension Viewport.coffee
define([
'jquery',
'use!underscore',
'use!backbone',
'mustache',
'text!template/__init__.html',
'model/account',
'view/header',
'view/footer',
'view/zaps/__init__',
'view/account/__init__',
],
($, _, Backbone, MustacheWrapper, InitTemplate, HeaderView, FooterView, ZapsView, AccountView) ->
Viewport = Backbone.View.extend
###
Top level view which controls entire viewport
###
events:
'click li[data-tab]': 'tabClick'
'click *[data-navlink]': 'navClick'
initialize: (options) ->
_.bindAll(@)
@.setElement($('body'))
@render()
render: (appView, options) ->
# If an appView was passed, render it into the app frame
if appView?
# unload previous view if it specified an unload function
if @appView?.unload?
@appView.unload.call(@appView)
# unbind all events attached to old view
if @appView?.undelegateEvents?
@appView.undelegateEvents()
defaults =
el: @$('*[data-app]')
account: @account
headerView: @headerView
footerView: @footerView
@appView = new appView($.extend(defaults, options))
# else render the normal viewport view
else
view =
place: 'holder'
@$el.html(Mustache.to_html(InitTemplate, view))
@headerView = new HeaderView
el: @$('div[data-header=true]')
account: @account
@footerView = new FooterView
el: @$('div[data-footer=true]')
account: @account
navigate: (path) ->
# Navigate to the path inside a new browser tab
chrome.tabs.create({url:"#{window.domain}/#{path}"})
window.close()
tabClick: (e) ->
# Called when a tab is clicked, handle navigation
tab = $(e.currentTarget).attr('data-tab')
load = (tab, view, options) =>
@$('ul[data-tabs]').find('li').removeClass('selected')
@$('ul[data-tabs]').find("li[data-tab=#{tab}]").addClass('selected')
@render(view, options)
switch tab
when "zaps" then load(tab, ZapsView, {})
when "account" then load(tab, AccountView, {})
return false # cancel click
navClick: (e) ->
# Link clicked to open an external link
path = $(e.currentTarget).attr('data-navlink')
@navigate(path)
return false # cancel click
return Viewport
)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment