mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
84f81d0eac
Expand folder to show highlighted file in file tree GitOrigin-RevId: 7fb9174fd71eb362655bcabf2f7884597aebee47
131 lines
3.6 KiB
JavaScript
131 lines
3.6 KiB
JavaScript
/* eslint-disable
|
|
camelcase,
|
|
max-len,
|
|
no-return-assign,
|
|
no-undef,
|
|
*/
|
|
// TODO: This file was created by bulk-decaffeinate.
|
|
// Fix any style issues and re-enable lint.
|
|
/*
|
|
* decaffeinate suggestions:
|
|
* DS101: Remove unnecessary use of Array.from
|
|
* DS102: Remove unnecessary code created because of implicit returns
|
|
* DS207: Consider shorter variations of null checks
|
|
* Full docs: https://github.com/decaffeinate/decaffeinate/blob/master/docs/suggestions.md
|
|
*/
|
|
define(['base'], App =>
|
|
App.controller('FileTreeFolderController', function(
|
|
$scope,
|
|
ide,
|
|
$modal,
|
|
localStorage
|
|
) {
|
|
$scope.expanded =
|
|
localStorage(`folder.${$scope.entity.id}.expanded`) || false
|
|
|
|
$scope.toggleExpanded = function() {
|
|
$scope.expanded = !$scope.expanded
|
|
$scope._storeCurrentStateInLocalStorage()
|
|
}
|
|
|
|
$scope.$on('entity-file:selected', function() {
|
|
$scope.expanded = true
|
|
$scope._storeCurrentStateInLocalStorage()
|
|
})
|
|
|
|
$scope._storeCurrentStateInLocalStorage = function() {
|
|
localStorage(`folder.${$scope.entity.id}.expanded`, $scope.expanded)
|
|
}
|
|
|
|
$scope.onDrop = function(events, ui) {
|
|
let entities
|
|
if (ide.fileTreeManager.multiSelectedCount()) {
|
|
entities = ide.fileTreeManager.getMultiSelectedEntityChildNodes()
|
|
} else {
|
|
entities = [$(ui.draggable).scope().entity]
|
|
}
|
|
for (let dropped_entity of Array.from(entities)) {
|
|
try {
|
|
ide.fileTreeManager.moveEntity(dropped_entity, $scope.entity)
|
|
} catch (err) {
|
|
$modal.open({
|
|
templateUrl: 'duplicateFileModalTemplate',
|
|
controller: 'DuplicateFileModalController',
|
|
resolve: {
|
|
fileName() {
|
|
return dropped_entity.name
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|
|
$scope.$digest()
|
|
// clear highlight explicitly
|
|
return $('.file-tree-inner .droppable-hover').removeClass(
|
|
'droppable-hover'
|
|
)
|
|
}
|
|
|
|
$scope.orderByFoldersFirst = function(entity) {
|
|
// We need this here as well as in FileTreeController
|
|
// since the file-entity diretive creates a new scope
|
|
// that doesn't inherit from previous scopes.
|
|
if ((entity != null ? entity.type : undefined) === 'folder') {
|
|
return '0'
|
|
}
|
|
return '1'
|
|
}
|
|
|
|
$scope.openNewDocModal = () =>
|
|
$modal.open({
|
|
templateUrl: 'newFileModalTemplate',
|
|
controller: 'NewFileModalController',
|
|
size: 'lg',
|
|
resolve: {
|
|
parent_folder() {
|
|
return $scope.entity
|
|
},
|
|
projectFeatures() {
|
|
return ide.$scope.project.features
|
|
},
|
|
type() {
|
|
return 'doc'
|
|
},
|
|
userFeatures() {
|
|
return ide.$scope.user.features
|
|
}
|
|
}
|
|
})
|
|
|
|
$scope.openNewFolderModal = () =>
|
|
$modal.open({
|
|
templateUrl: 'newFolderModalTemplate',
|
|
controller: 'NewFolderModalController',
|
|
resolve: {
|
|
parent_folder() {
|
|
return $scope.entity
|
|
}
|
|
}
|
|
})
|
|
|
|
return ($scope.openUploadFileModal = () =>
|
|
$modal.open({
|
|
templateUrl: 'newFileModalTemplate',
|
|
controller: 'NewFileModalController',
|
|
size: 'lg',
|
|
resolve: {
|
|
parent_folder() {
|
|
return $scope.entity
|
|
},
|
|
projectFeatures() {
|
|
return ide.$scope.project.features
|
|
},
|
|
type() {
|
|
return 'upload'
|
|
},
|
|
userFeatures() {
|
|
return ide.$scope.user.features
|
|
}
|
|
}
|
|
}))
|
|
}))
|