engine/app/assets/javascripts/locomotive/views/theme_assets/index_view.js.coffee

84 lines
2.2 KiB
CoffeeScript

Locomotive.Views.ThemeAssets ||= {}
class Locomotive.Views.ThemeAssets.IndexView extends Backbone.View
el: '#content'
_lists_views: []
initialize: ->
_.bindAll(@, 'add_asset')
render: ->
@build_uploader()
@render_snippets()
@render_images()
@render_js_and_css()
@render_fonts()
@render_media()
return @
build_uploader: ->
form = @$('#theme-assets-quick-upload')
input = form.find('input[type=file]')
link = form.find('a.new')
link.bind 'click', (event) ->
event.stopPropagation() & event.preventDefault()
input.click()
input.bind 'change', (event) =>
_.each event.target.files, (file) =>
asset = new Locomotive.Models.ThemeAsset(source: file)
asset.save {}, success: @add_asset, headers: { 'X-Flash': true }
add_asset: (model) ->
list_view = @pick_list_view(model.get('content_type'))
list_view.collection.add(model)
render_snippets: ->
@render_list 'snippets', @options.snippets, Locomotive.Views.Snippets.ListView
render_images: ->
@render_list 'images', @options.images
render_js_and_css: ->
@render_list 'js-and-css', @options.js_and_css_assets, Locomotive.Views.ThemeAssets.ListView, ich.js_and_css_list
render_fonts: ->
@render_list 'fonts', @options.fonts, Locomotive.Views.ThemeAssets.ListView, ich.fonts_list
render_media: ->
@render_list 'media', @options.media, Locomotive.Views.ThemeAssets.ListView, ich.media_list
render_list: (type, collection, view_klass, template) ->
return if @$("##{type}-anchor").size() == 0
view_klass ||= Locomotive.Views.ThemeAssets.ListView
view = new view_klass(collection: collection, type: type)
if template?
view.template = -> template
@$("##{type}-anchor").replaceWith(view.render().el)
(@_lists_views ||= []).push(view)
pick_list_view: (content_type) ->
type = switch content_type
when 'image' then 'images'
when 'javascript', 'stylesheet' then 'js-and-css'
when 'media' then 'media'
when 'font' then 'fonts'
_.find @_lists_views, (view) => view.options.type == type
remove: ->
_.each @_lists_views, (view) => view.remove()
super