1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
/**
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
import { Permission, Node, FileType, View, FileAction, DefaultType } from '@nextcloud/files'
import { translate as t } from '@nextcloud/l10n'
import FolderSvg from '@mdi/svg/svg/folder.svg?raw'
export const action = new FileAction({
id: 'open-folder',
displayName(files: Node[]) {
// Only works on single node
const displayName = files[0].attributes.displayname || files[0].basename
return t('files', 'Open folder {displayName}', { displayName })
},
iconSvgInline: () => FolderSvg,
enabled(nodes: Node[]) {
// Only works on single node
if (nodes.length !== 1) {
return false
}
const node = nodes[0]
if (!node.isDavRessource) {
return false
}
return node.type === FileType.Folder
&& (node.permissions & Permission.READ) !== 0
},
async exec(node: Node, view: View) {
if (!node || node.type !== FileType.Folder) {
return false
}
window.OCP.Files.Router.goToRoute(
null,
{ view: view.id, fileid: node.fileid },
{ dir: node.path },
)
return null
},
// Main action if enabled, meaning folders only
default: DefaultType.HIDDEN,
order: -100,
})
|