codecombat/app/views/play/level/level_loading_view.coffee

48 lines
1.6 KiB
CoffeeScript
Raw Normal View History

2014-03-14 20:06:08 -04:00
View = require 'views/kinds/CocoView'
template = require 'templates/play/level/level_loading'
2014-03-16 20:07:10 -04:00
2014-03-14 20:06:08 -04:00
module.exports = class LevelLoadingView extends View
id: "level-loading-view"
template: template
subscriptions:
'level-loader:progress-changed': 'onLevelLoaderProgressChanged'
2014-03-19 20:11:45 -04:00
afterRender: ->
2014-03-17 03:12:11 -04:00
@$el.find('.tip.rare').remove() if _.random(1, 10) < 9
tips = @$el.find('.tip').addClass('to-remove')
tip = _.sample(tips)
2014-03-17 03:12:11 -04:00
$(tip).removeClass('to-remove')
@$el.find('.to-remove').remove()
@hideLoading()
2014-03-14 20:06:08 -04:00
onLevelLoaderProgressChanged: (e) ->
@progress = e.progress
2014-03-17 03:05:45 -04:00
@progress = 0.01 if @progress < 0.01
2014-03-14 20:06:08 -04:00
@updateProgressBar()
updateProgressBar: ->
@$el.find('.progress-bar').css('width', (100 * @progress) + '%')
showReady: ->
ready = $.i18n.t('play_level.loading_ready', defaultValue: 'Ready!')
@$el.find('#tip-wrapper .tip').addClass('ready').text ready
Backbone.Mediator.publish 'play-sound', trigger: 'loading_ready', volume: 0.75
2014-03-14 20:06:08 -04:00
unveil: ->
2014-03-14 22:44:19 -04:00
_.delay @reallyUnveil, 1000
2014-03-14 20:06:08 -04:00
reallyUnveil: =>
return if @destroyed or @progress < 1
2014-03-14 20:06:08 -04:00
loadingDetails = @$el.find('.loading-details')
duration = parseFloat loadingDetails.css 'transition-duration'
loadingDetails.css 'top', -loadingDetails.outerHeight(true)
2014-03-14 22:44:19 -04:00
@$el.find('.left-wing').css left: '-100%', backgroundPosition: 'right -400px top 0'
@$el.find('.right-wing').css right: '-100%', backgroundPosition: 'left -400px top 0'
2014-03-14 20:06:08 -04:00
_.delay @onUnveilEnded, duration * 1000
onUnveilEnded: =>
return if @destroyed
Backbone.Mediator.publish 'onLoadingViewUnveiled', view: @