mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-24 16:17:57 -05:00
2855d2a402
Made conflict finding a bit more liberal, in that any messing with arrays (adding, removing or moving things inside) will conflict with any other such change.
124 lines
5 KiB
CoffeeScript
124 lines
5 KiB
CoffeeScript
View = require 'views/kinds/RootView'
|
|
template = require 'templates/editor/level/edit'
|
|
Level = require 'models/Level'
|
|
LevelSystem = require 'models/LevelSystem'
|
|
World = require 'lib/world/world'
|
|
DocumentFiles = require 'collections/DocumentFiles'
|
|
LevelLoader = require 'lib/LevelLoader'
|
|
|
|
ThangsTabView = require './thangs_tab_view'
|
|
SettingsTabView = require './settings_tab_view'
|
|
ScriptsTabView = require './scripts_tab_view'
|
|
ComponentsTabView = require './components_tab_view'
|
|
SystemsTabView = require './systems_tab_view'
|
|
LevelSaveView = require './save_view'
|
|
LevelForkView = require './fork_view'
|
|
SaveVersionModal = require 'views/modal/save_version_modal'
|
|
PatchesView = require 'views/editor/patches_view'
|
|
VersionHistoryView = require './versions_view'
|
|
ErrorView = require '../../error_view'
|
|
|
|
module.exports = class EditorLevelView extends View
|
|
id: "editor-level-view"
|
|
template: template
|
|
cache: false
|
|
|
|
events:
|
|
'click #play-button': 'onPlayLevel'
|
|
'click #commit-level-start-button': 'startCommittingLevel'
|
|
'click #fork-level-start-button': 'startForkingLevel'
|
|
'click #level-history-button': 'showVersionHistory'
|
|
'click #patches-tab': -> @patchesView.load()
|
|
'click #components-tab': -> @componentsTab.refreshLevelThangsTreema @level.get('thangs')
|
|
'click #level-patch-button': 'startPatchingLevel'
|
|
'click #level-watch-button': 'toggleWatchLevel'
|
|
'click #pop-level-i18n-button': -> @level.populateI18N()
|
|
'mouseup .nav-tabs > li a': 'toggleTab'
|
|
|
|
constructor: (options, @levelID) ->
|
|
super options
|
|
@supermodel.shouldSaveBackups = (model) ->
|
|
model.constructor.className in ['Level', 'LevelComponent', 'LevelSystem']
|
|
@levelLoader = new LevelLoader supermodel: @supermodel, levelID: @levelID, headless: true, editorMode: true
|
|
@level = @levelLoader.level
|
|
@files = new DocumentFiles(@levelLoader.level)
|
|
@supermodel.loadCollection(@files, 'file_names')
|
|
|
|
showLoading: ($el) ->
|
|
$el ?= @$el.find('.outer-content')
|
|
super($el)
|
|
|
|
onLoaded: ->
|
|
_.defer =>
|
|
@world = @levelLoader.world
|
|
@render()
|
|
|
|
getRenderData: (context={}) ->
|
|
context = super(context)
|
|
context.level = @level
|
|
context.authorized = me.isAdmin() or @level.hasWriteAccess(me)
|
|
context.anonymous = me.get('anonymous')
|
|
context
|
|
|
|
afterRender: ->
|
|
super()
|
|
return unless @supermodel.finished()
|
|
@$el.find('a[data-toggle="tab"]').on 'shown.bs.tab', (e) =>
|
|
Backbone.Mediator.publish 'level:view-switched', e
|
|
@thangsTab = @insertSubView new ThangsTabView world: @world, supermodel: @supermodel, level: @level
|
|
@settingsTab = @insertSubView new SettingsTabView supermodel: @supermodel
|
|
@scriptsTab = @insertSubView new ScriptsTabView world: @world, supermodel: @supermodel, files: @files
|
|
@componentsTab = @insertSubView new ComponentsTabView supermodel: @supermodel
|
|
@systemsTab = @insertSubView new SystemsTabView supermodel: @supermodel
|
|
Backbone.Mediator.publish 'level-loaded', level: @level
|
|
@showReadOnly() if me.get('anonymous')
|
|
@patchesView = @insertSubView(new PatchesView(@level), @$el.find('.patches-view'))
|
|
@listenTo @patchesView, 'accepted-patch', -> location.reload()
|
|
@$el.find('#level-watch-button').find('> span').toggleClass('secret') if @level.watching()
|
|
|
|
onPlayLevel: (e) ->
|
|
sendLevel = =>
|
|
@childWindow.Backbone.Mediator.publish 'level-reload-from-data', level: @level, supermodel: @supermodel
|
|
if @childWindow and not @childWindow.closed
|
|
# Reset the LevelView's world, but leave the rest of the state alone
|
|
sendLevel()
|
|
else
|
|
# Create a new Window with a blank LevelView
|
|
scratchLevelID = @level.get('slug') + "?dev=true"
|
|
@childWindow = window.open("/play/level/#{scratchLevelID}", 'child_window', 'width=1024,height=560,left=10,top=10,location=0,menubar=0,scrollbars=0,status=0,titlebar=0,toolbar=0', true)
|
|
@childWindow.onPlayLevelViewLoaded = (e) => sendLevel() # still a hack
|
|
@childWindow.focus()
|
|
|
|
startPatchingLevel: (e) ->
|
|
@openModalView new SaveVersionModal({model:@level})
|
|
Backbone.Mediator.publish 'level:view-switched', e
|
|
|
|
startCommittingLevel: (e) ->
|
|
@openModalView new LevelSaveView level: @level, supermodel: @supermodel
|
|
Backbone.Mediator.publish 'level:view-switched', e
|
|
|
|
startForkingLevel: (e) ->
|
|
levelForkView = new LevelForkView level: @level
|
|
@openModalView levelForkView
|
|
Backbone.Mediator.publish 'level:view-switched', e
|
|
|
|
showVersionHistory: (e) ->
|
|
versionHistoryView = new VersionHistoryView level:@level, @levelID
|
|
@openModalView versionHistoryView
|
|
Backbone.Mediator.publish 'level:view-switched', e
|
|
|
|
toggleWatchLevel: ->
|
|
button = @$el.find('#level-watch-button')
|
|
@level.watch(button.find('.watch').is(':visible'))
|
|
button.find('> span').toggleClass('secret')
|
|
|
|
toggleTab: (e) ->
|
|
@renderScrollbar()
|
|
return unless $(document).width() <= 800
|
|
li = $(e.target).closest('li')
|
|
if li.hasClass('active')
|
|
li.parent().find('li').show()
|
|
else
|
|
li.parent().find('li').hide()
|
|
li.show()
|
|
console.log li.hasClass('active')
|