Files
atom/src/extensions/tree-view/tree-view.coffee
2012-05-02 08:27:35 -07:00

100 lines
3.2 KiB
CoffeeScript

{View, $$} = require 'space-pen'
Directory = require 'directory'
DirectoryView = require 'tree-view/directory-view'
FileView = require 'tree-view/file-view'
MoveDialog = require 'tree-view/move-dialog'
AddDialog = require 'tree-view/add-dialog'
$ = require 'jquery'
_ = require 'underscore'
module.exports =
class TreeView extends View
@activate: (rootView) ->
requireStylesheet 'tree-view.css'
rootView.horizontal.prepend(new TreeView(rootView))
@content: (rootView) ->
@div class: 'tree-view', tabindex: -1, =>
@subview 'root', new DirectoryView(directory: rootView.project.getRootDirectory(), isExpanded: true)
initialize: (@rootView) ->
@on 'click', '.entry', (e) =>
entry = $(e.currentTarget).view()
@selectEntry(entry)
@openSelectedEntry() if (entry instanceof FileView)
false
@on 'move-up', => @moveUp()
@on 'move-down', => @moveDown()
@on 'tree-view:expand-directory', => @expandDirectory()
@on 'tree-view:collapse-directory', => @collapseDirectory()
@on 'tree-view:open-selected-entry', => @openSelectedEntry()
@on 'tree-view:move', => @move()
@on 'tree-view:add', => @add()
@on 'tree-view:directory-change', => @selectActiveFile()
@rootView.on 'active-editor-path-change', => @selectActiveFile()
@on 'tree-view:unfocus', => @rootView.activeEditor().focus()
@rootView.on 'tree-view:focus', => this.focus()
deactivate: ->
@root.unwatchEntries()
selectActiveFile: ->
activeFilePath = @rootView.activeEditor()?.buffer.path
for element in @find(".file")
fileView = $(element).view()
if fileView.getPath() == activeFilePath
@selectEntry(fileView)
moveDown: ->
selectedEntry = @selectedEntry()
if selectedEntry
if selectedEntry.is('.expanded.directory')
return if @selectEntry(selectedEntry.find('.entry:first'))
return if @selectEntry(selectedEntry.next())
return if @selectEntry(selectedEntry.closest('.directory').next())
else
@selectEntry(@root)
moveUp: ->
selectedEntry = @selectedEntry()
if selectedEntry
return if @selectEntry(selectedEntry.prev())
return if @selectEntry(selectedEntry.parents('.directory').first())
else
@selectEntry(@find('.entry').last())
expandDirectory: ->
selectedEntry = @selectedEntry()
selectedEntry.view().expand() if (selectedEntry instanceof DirectoryView)
collapseDirectory: ->
selectedEntry = @selectedEntry()
directory = selectedEntry.closest('.expanded.directory').view()
directory.collapse()
@selectEntry(directory)
openSelectedEntry: ->
selectedEntry = @selectedEntry()
if (selectedEntry instanceof DirectoryView)
selectedEntry.view().toggleExpansion()
else if (selectedEntry instanceof FileView)
@rootView.open(selectedEntry.getPath())
move: ->
@rootView.append(new MoveDialog(@rootView.project, @selectedEntry().getPath()))
add: ->
@rootView.append(new AddDialog(@rootView, @selectedEntry().getPath()))
selectedEntry: ->
@find('.selected')?.view()
selectEntry: (entry) ->
return false unless entry.get(0)
@find('.selected').removeClass('selected')
entry.addClass('selected')