@dotglitch/ngx-common 1.1.26 → 1.1.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -230,9 +230,9 @@ export class FilemanagerComponent {
|
|
|
230
230
|
let path = file.path + file.name;
|
|
231
231
|
if (file.kind == "directory" && !path.endsWith('/'))
|
|
232
232
|
path += "/";
|
|
233
|
-
const url = this.config.apiSettings.
|
|
234
|
-
? this.config.apiSettings.
|
|
235
|
-
: this.config.apiSettings.
|
|
233
|
+
const url = this.config.apiSettings.downloadEntryUrlTemplate
|
|
234
|
+
? this.config.apiSettings.downloadEntryUrlTemplate(path)
|
|
235
|
+
: this.config.apiSettings.downloadEntryUrl;
|
|
236
236
|
// window.open(target);
|
|
237
237
|
var link = document.createElement("a");
|
|
238
238
|
link.download = file.name;
|
|
@@ -314,4 +314,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
314
314
|
}], filesSelect: [{
|
|
315
315
|
type: Output
|
|
316
316
|
}] } });
|
|
317
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filemanager.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/filemanager/filemanager.component.ts","../../../../../packages/common/src/components/filemanager/filemanager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnInit, Optional, Output, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { NgForOf, NgIf } from '@angular/common';\nimport { MatTabGroup, MatTabsModule } from '@angular/material/tabs';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatDrawerContainer, MatSidenavModule } from '@angular/material/sidenav';\nimport { AngularSplitModule } from 'angular-split';\n\nimport { FileGridComponent } from './file-grid/file-grid.component';\nimport { ToolbarComponent } from './toolbar/toolbar.component';\nimport { TreeViewComponent } from './tree-view/tree-view.component';\nimport { FileSorting, NGX_WEB_COMPONENTS_CONFIG, NgxWebComponentsConfig } from '../types';\nimport { IconResolver } from './icon-resolver';\nimport { LazyLoaderService, NGX_LAZY_LOADER_CONFIG } from '../lazy-loader/lazy-loader.service';\nimport { Fetch } from '../../public-api';\nimport { ulid } from 'ulidx';\n\n// TODO:\n/**\n * Multiple music / video / image files selected turns into a playlist\n * Dragging music / video / image queues the file(s)\n * Can save and edit a list of files as playlist\n * Can \"loop\" \"randomize\"\n */\n\nexport type DirectoryDescriptor = {\n    kind: \"directory\",\n    path: string,\n    name: string\n    contents: {\n        dirs: DirectoryDescriptor[],\n        files: FileDescriptor[]\n    }\n}\n\nexport type FileDescriptor = {\n    kind: \"file\",\n    stats: {\n        size: number;\n        // Size for zipped file\n        compressedSize?: number,\n        atimeMs: number;\n        mtimeMs: number;\n        ctimeMs: number;\n        birthtimeMs: number;\n    },\n    path: string\n    name: string,\n    ext: string,\n    // Comment for entries in a zip file.\n    comment?: string\n};\n\nexport type FSDescriptor = DirectoryDescriptor | FileDescriptor;\n\nexport type FileViewTab = {\n    id: string,\n    label: string,\n    breadcrumb: {\n        id: string,\n        label: string\n    }[],\n    path: string,\n    selection: FSDescriptor[],\n    viewMode: \"grid\" | \"list\",\n    historyIndex: number,\n    history: string[],\n    sidebarItems: FSDescriptor[],\n    sortOrder: FileSorting\n}\n\n// TODO: replace http configs\ntype HttpConfiguration = (\n    { url: string } |\n    { urlTemplate: (path: string) => string }\n) & {\n    method?: \"get\" | \"put\" | \"post\" | \"patch\" | \"delete\",\n    headers?: { [key: string]: string }\n}\n\nexport type NgxFileManagerConfiguration = Partial<{\n    /**\n     * Initial path\n     */\n    path: string,\n\n    /**\n     * Custom root path (will appear as '/').\n     * Defaults to '/'.\n     *\n     * User cannot view outside of this path.\n     *   (Not to be used as a security measure!)\n     */\n    chrootPath: string,\n\n    /**\n     * Restrict users to only navigate around to subpaths of the specified `path`\n     */\n    navigateOnlyToDescendants: boolean,\n    showBreadcrumb: boolean,\n    showTreeview: boolean,\n\n    /**\n     * Name of the \"root\" path `/`\n     * Defaults to \"Storage\"\n     */\n    rootName: string,\n\n    /**\n     * Maximum number of items to be stored in history.\n     */\n    maxHistoryLength: number,\n\n    apiSettings: {\n        listEntriesUrl?: string,\n        listEntriesUrlTemplate?: (path: string) => string,\n        downloadEntryUrl?: string,\n        downloadEntryUrlTemplate?: (path: string) => string,\n        uploadEntryUrl?: string,\n        uploadEntryUrlTemplate?: (path: string) => string,\n        deleteEntryUrl?: string,\n        deleteEntryUrlTemplate?: (path: string) => string,\n        renameEntryUrl?: string,\n        renameEntryUrlTemplate?: (path: string) => string,\n        createDirectoryUrl?: string,\n        createDirectoryUrlTemplate?: (path: string) => string\n    },\n\n    /**\n     * The path that images are loaded from.\n     * Default value `/assets/dotglitch/webcomponents/`\n     */\n    assetPath: string,\n    sidebarLocationStrategy: \"known\" | \"currentDirectory\",\n\n    iconResolver: (file: FSDescriptor) => string,\n\n    imageSize: \"normal\" | \"small\" | \"huge\",\n\n    /**\n     *\n     */\n    selectionMode: \"single\" | \"multiple\",\n\n    /**\n     * This determines if the filemanager shows selected entries\n     *\n     * If set to `focusFiles`, file paths that match from the provided `focusedFiles`\n     * will be highlighted, and can be selected / deselected.\n     */\n    mode: \"focusFiles\" | \"normal\",\n    focusedFiles: string[]\n}>\n\n@Component({\n    selector: 'app-filemanager',\n    templateUrl: './filemanager.component.html',\n    styleUrls: ['./filemanager.component.scss'],\n    imports: [\n        NgIf,\n        NgForOf,\n        AngularSplitModule,\n        FileGridComponent,\n        MatTabsModule,\n        MatIconModule,\n        MatSidenavModule,\n        ToolbarComponent,\n        TreeViewComponent\n    ],\n    standalone: true\n})\nexport class FilemanagerComponent implements OnInit {\n    @ViewChild('tabGroup') tabGroup: MatTabGroup;\n    @ViewChildren(FileGridComponent) fileGrids: QueryList<FileGridComponent>;\n    @ViewChild(TreeViewComponent) treeView: TreeViewComponent;\n    @ViewChild(ToolbarComponent) toolbar: ToolbarComponent;\n    @ViewChild(MatDrawerContainer) drawer: MatDrawerContainer;\n\n    @Input() config: NgxFileManagerConfiguration = {\n        apiSettings: {\n            listEntriesUrl: `/api/filesystem/`,\n            uploadEntryUrl: `/api/filesystem/`,\n            downloadEntryUrl: `/api/filesystem/`,\n            deleteEntryUrl: `/api/filesystem/`,\n            createDirectoryUrl: `/api/filesystem/folder`,\n            renameEntryUrl: `/api/filesystem/rename`\n        }\n    };\n\n    @Input() gridSize: \"small\" | \"normal\" | \"large\" = \"normal\";\n    @Input() mode: \"grid\" | \"list\";\n    @Input() contextTags: {[key: string]: string};\n\n\n    @Input() value: FSDescriptor[] = [];\n    @Output() valueChange = new EventEmitter<FSDescriptor[]>();\n\n    gridValues: FSDescriptor[][] = [];\n\n    /**\n     * Emits when focused files change.\n     * Only available in `focusFiles` mode.\n     */\n    @Output() focusedFilesChange = new EventEmitter();\n    /**\n     * Emits when a file is uploaded.\n     */\n    @Output() fileUpload = new EventEmitter();\n    /**\n     * Emits when a file is downloaded.\n     */\n    @Output() fileDownload = new EventEmitter();\n    @Output() fileRename = new EventEmitter();\n    @Output() fileDelete = new EventEmitter();\n    @Output() fileCopy = new EventEmitter();\n    @Output() filePaste = new EventEmitter();\n\n    @Output() fileSelect = new EventEmitter<FileDescriptor>();\n    @Output() fileDblClick = new EventEmitter<FileDescriptor>();\n    @Output() folderSelect = new EventEmitter<DirectoryDescriptor>();\n    @Output() folderDblClick = new EventEmitter<DirectoryDescriptor>();\n\n    /**\n     * Emits when multiple file selections change.\n     */\n    @Output() filesSelect = new EventEmitter<FSDescriptor[]>();\n    /**\n     * Emits when any selection changes, single or multiple files.\n     */\n    // @Output() selectionChange = new EventEmitter<FSDescriptor[]>();\n\n    showHiddenFiles = false;\n    showSidebar = true;\n    sidebarOverlay = false;\n    width = 0;\n\n    isHomeAncestor = false;\n\n    currentTab: FileViewTab = {} as any;\n    get currentFileGrid() { return this.fileGrids.get(this.tabIndex) }\n    tabIndex = 0;\n    tabs: FileViewTab[] = [];\n\n    iconResolver: IconResolver;\n\n    constructor (\n        @Optional() @Inject(NGX_WEB_COMPONENTS_CONFIG) readonly libConfig: NgxWebComponentsConfig = {},\n        private readonly lazyLoader: LazyLoaderService,\n        private viewContainer: ViewContainerRef,\n        private fetch: Fetch\n    ) {\n        lazyLoader.registerComponent({\n            id: \"folder-rename\",\n            group: \"@dotglitch/ngx-web-components\",\n            load: () => import('./folder-rename/folder-rename.component')\n        })\n\n        this.iconResolver = new IconResolver(libConfig.assetPath);\n    }\n\n    ngOnInit(): void {\n        this.initTab(this.config.path);\n        this.currentTab = this.tabs[0];\n    }\n\n    ngAfterViewInit() {\n        this.onResize();\n\n        setTimeout(() => this.onResize(), 250);\n    }\n\n    onTreeViewLoadChildren({item, cb}) {\n        const url = this.config.apiSettings.listEntriesUrlTemplate\n                  ? this.config.apiSettings.listEntriesUrlTemplate(item.path + item.name)\n                  : this.config.apiSettings.listEntriesUrl\n\n        this.fetch.post(url, { path: item.path + item.name, showHidden: this.showHiddenFiles })\n            .then((data: any) => {\n                const dirs: DirectoryDescriptor[] = data.dirs;\n                cb(dirs);\n            })\n    }\n\n    initTab(path: string) {\n        this.tabs.push(this.currentTab = {\n            id: ulid(),\n            label: this.getTabLabel(path),\n            breadcrumb: this.calcBreadcrumb(path),\n            path,\n            selection: [],\n            viewMode: this.mode || 'grid',\n            historyIndex: 0,\n            history: [],\n            sidebarItems: [],\n            sortOrder: 'a-z'\n        });\n        this.tabIndex = this.tabs.length;\n    }\n\n    closeTab(tab: FileViewTab) {\n        this.tabs.splice(this.tabs.findIndex(t => t.id == tab.id), 1);\n    }\n\n    calcBreadcrumb(path: string) {\n        if (!path) return null;\n\n        path = path.replace(\"#/\", '/');\n\n        // If we're acting like we're in a changed root, we wipe out\n        // breadcrumbs below the root\n        if (this.config.chrootPath) {\n            path = path.replace(this.config.chrootPath, '');\n            const parts = path.split('/');\n\n            path = path.replace(/^\\//, this.config.chrootPath);\n            return parts.map((p, i) => {\n                const path = parts.slice(0, i + 1).join('/');\n\n                return {\n                    id: (this.config.chrootPath + (path || '/')).replace(/\\/+/g, '/'),\n                    label: p || \"\"\n                };\n            });\n        }\n        else {\n            const parts = path.split('/');\n\n            return parts.map((p, i) => {\n                const path = parts.slice(0, i + 1).join('/');\n\n                return {\n                    id: path || '/',\n                    label: p || \"\"\n                };\n            });\n        }\n    }\n\n    onBreadcrumbClick(crumb) {\n        if (crumb.id) {\n            this.currentTab.path = crumb.id;\n            this.currentTab.breadcrumb = this.calcBreadcrumb(crumb.id);\n        }\n    }\n\n    onTabPathChange(tab: FileViewTab) {\n        tab.label = this.getTabLabel(tab.path);\n        tab.breadcrumb = this.calcBreadcrumb(tab.path);\n\n        tab.historyIndex++;\n        tab.history.push(tab.path);\n        tab.history.splice(typeof this.config.maxHistoryLength == 'number' ? this.config.maxHistoryLength : 50);\n    }\n\n    onTreeViewSelect(item: FSDescriptor) {\n        this.currentTab.path = item.path + item.name;\n    }\n\n    onTabLoadFiles(tab: FileViewTab, files: FSDescriptor[]) {\n        if (tab.sidebarItems.length == 0) {\n            tab.sidebarItems = files.filter(f => f.kind == \"directory\");\n            return;\n        }\n\n        const currentItems = tab.sidebarItems;\n        const dirItems = files.filter(f => f.kind == \"directory\");\n\n        function recurse(items) {\n            return items.find(i => tab.path?.startsWith(i.path));\n        }\n        const target = recurse(currentItems);\n\n        if (target)\n            target['_children'] = dirItems;\n\n        tab.sidebarItems = currentItems;\n    }\n\n    onGridValueChange() {\n        this.value = this.gridValues.flat(1);\n        this.valueChange.emit(this.value)\n    }\n\n    getTabLabel(path: string) {\n        return path?.split('/').filter(p => p).pop();\n    }\n\n    async onResize() {\n        // Trigger re-calculation of the view\n        this.fileGrids.forEach(g => g.resize());\n\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n        const bounds = el.getBoundingClientRect();\n        this.width = bounds.width;\n\n        // If the view area is less than 650px wide, use overlay the sidebar panel\n        this.sidebarOverlay = bounds.width < 650;\n        if (this.sidebarOverlay == false && [...this.drawer._drawers][0].opened) {\n            this.drawer.close();\n        }\n    }\n\n    async onResizeEnd() {\n        this.onResize();\n\n        setTimeout(() => this.onResize(), 250);\n    }\n\n    getSelection() {\n        if (this.currentTab.viewMode == \"grid\") {\n            return this.currentTab.selection\n        }\n        else {\n            return this.value;\n        }\n    }\n\n    clearSelection() {\n        this.fileGrids.forEach(g => g.clearSelection());\n    }\n\n    // Tell the child grid to refresh it's sorting\n    refreshSorting() {\n        this.fileGrids.forEach(g => g.sort());\n    }\n\n    refreshData() {\n        this.fileGrids.forEach(g => g.loadFolder());\n    }\n\n    getFileData(file: FileDescriptor) {\n        let url = this.config.apiSettings.renameEntryUrlTemplate\n            ? this.config.apiSettings.renameEntryUrlTemplate(file.path + file.name)\n            : this.config.apiSettings.renameEntryUrl;\n\n        url = (url.includes('?') ? '&' : '?') + `dir=${file.path}&file=${file.name}`;\n\n        return url;\n    }\n\n    downloadFile(file: FSDescriptor) {\n        let path = file.path + file.name;\n        if (file.kind == \"directory\" && !path.endsWith('/'))\n            path += \"/\";\n\n        const url = this.config.apiSettings.deleteEntryUrlTemplate\n            ? this.config.apiSettings.deleteEntryUrlTemplate(path)\n            : this.config.apiSettings.deleteEntryUrl;\n\n        // window.open(target);\n        var link = document.createElement(\"a\");\n        link.download = file.name;\n        link.href = url;\n        link.click();\n        link.remove();\n        this.fileDownload.next(file);\n    }\n}\n","<app-toolbar\n    [currentTab]=\"currentTab\"\n    [(showHiddenFiles)]=\"showHiddenFiles\"\n    [(showSidebar)]=\"showSidebar\"\n    [config]=\"config\"\n    [showBareMinimum]=\"width < 500 && config.showBreadcrumb != false\"\n    (onBreadcrumbClick)=\"onBreadcrumbClick($event)\"\n/>\n\n<mat-drawer-container>\n    <mat-drawer #drawer mode=\"over\">\n        <app-toolbar\n            *ngIf=\"width < 500 && config.showBreadcrumb != false\"\n            [currentTab]=\"currentTab\"\n            [(showHiddenFiles)]=\"showHiddenFiles\"\n            [(showSidebar)]=\"showSidebar\"\n            [config]=\"config\"\n            [drawerMode]=\"true\"\n            (onBreadcrumbClick)=\"onBreadcrumbClick($event)\"\n        />\n        <app-tree-view\n            [data]=\"currentTab.sidebarItems\"\n            (loadChildren)=\"onTreeViewLoadChildren($event)\"\n            (click)=\"onTreeViewSelect($event)\"\n        />\n    </mat-drawer>\n    <mat-drawer-content>\n        <as-split direction=\"horizontal\" [gutterSize]=\"sidebarOverlay ? 0 : 2\" [unit]=\"'pixel'\" (dragEnd)=\"onResizeEnd()\">\n            <as-split-area\n                style=\"background-color: var(--filemanager-sidebar-background-color, #2c2c2c)\"\n                [size]=\"215\"\n                [minSize]=\"215\"\n                [maxSize]=\"width/4\"\n                [visible]=\"!sidebarOverlay && config.showTreeview != false\"\n            >\n                <div class=\"sidebar\"\n                    *ngIf=\"!sidebarOverlay && config.showTreeview != false\"\n                    (click)=\"currentTab.selection = []\"\n                >\n                    <app-tree-view\n                        [data]=\"currentTab.sidebarItems\"\n                        (loadChildren)=\"onTreeViewLoadChildren($event)\"\n                        (click)=\"onTreeViewSelect($event)\"\n                    />\n                </div>\n            </as-split-area>\n            <as-split-area style=\"background-color: var(--filemanager-background-color, #272727);\">\n                <div class=\"content\"\n                    [style.--tab-height]=\"tabs.length > 1 ? '36px' : '0'\"\n                >\n                    <mat-tab-group #tabGroup (selectedTabChange)=\"currentTab = tabs[$event.index]\" [(selectedIndex)]=\"tabIndex\">\n                        <mat-tab *ngFor=\"let tab of tabs; let i = index\">\n                            <ng-template mat-tab-label>\n                                {{tab.label}}\n                                <mat-icon\n                                    class=\"close\"\n                                    (click)=\"closeTab(tab)\">\n                                    close\n                                </mat-icon>\n                            </ng-template>\n\n                            <ng-template matTabContent>\n                                <app-file-grid\n                                    [viewMode]=\"tab.viewMode\"\n                                    [tab]=\"tab\"\n                                    [config]=\"config\"\n                                    [gridSize]=\"gridSize\"\n                                    [sortOrder]=\"tab.sortOrder\"\n                                    [(selection)]=\"tab.selection\"\n                                    [(path)]=\"tab.path\"\n                                    (pathChange)=\"onTabPathChange(tab)\"\n                                    [(value)]=\"gridValues[i]\"\n                                    (valueChange)=\"onGridValueChange()\"\n                                    (loadFiles)=\"onTabLoadFiles(tab, $event)\"\n\n                                    (fileSelect)=\"fileSelect.next($event)\"\n                                    (fileDblClick)=\"fileDblClick.next($event)\"\n                                    (folderSelect)=\"folderSelect.next($event)\"\n                                    (folderDblClick)=\"folderDblClick.next($event)\"\n                                />\n                            </ng-template>\n                        </mat-tab>\n                    </mat-tab-group>\n                </div>\n            </as-split-area>\n        </as-split>\n    </mat-drawer-content>\n</mat-drawer-container>\n\n"]}
|
|
317
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filemanager.component.js","sourceRoot":"","sources":["../../../../../packages/common/src/components/filemanager/filemanager.component.ts","../../../../../packages/common/src/components/filemanager/filemanager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnInit, Optional, Output, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { NgForOf, NgIf } from '@angular/common';\nimport { MatTabGroup, MatTabsModule } from '@angular/material/tabs';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatDrawerContainer, MatSidenavModule } from '@angular/material/sidenav';\nimport { AngularSplitModule } from 'angular-split';\n\nimport { FileGridComponent } from './file-grid/file-grid.component';\nimport { ToolbarComponent } from './toolbar/toolbar.component';\nimport { TreeViewComponent } from './tree-view/tree-view.component';\nimport { FileSorting, NGX_WEB_COMPONENTS_CONFIG, NgxWebComponentsConfig } from '../types';\nimport { IconResolver } from './icon-resolver';\nimport { LazyLoaderService, NGX_LAZY_LOADER_CONFIG } from '../lazy-loader/lazy-loader.service';\nimport { Fetch } from '../../public-api';\nimport { ulid } from 'ulidx';\n\n// TODO:\n/**\n * Multiple music / video / image files selected turns into a playlist\n * Dragging music / video / image queues the file(s)\n * Can save and edit a list of files as playlist\n * Can \"loop\" \"randomize\"\n */\n\nexport type DirectoryDescriptor = {\n    kind: \"directory\",\n    path: string,\n    name: string\n    contents: {\n        dirs: DirectoryDescriptor[],\n        files: FileDescriptor[]\n    }\n}\n\nexport type FileDescriptor = {\n    kind: \"file\",\n    stats: {\n        size: number;\n        // Size for zipped file\n        compressedSize?: number,\n        atimeMs: number;\n        mtimeMs: number;\n        ctimeMs: number;\n        birthtimeMs: number;\n    },\n    path: string\n    name: string,\n    ext: string,\n    // Comment for entries in a zip file.\n    comment?: string\n};\n\nexport type FSDescriptor = DirectoryDescriptor | FileDescriptor;\n\nexport type FileViewTab = {\n    id: string,\n    label: string,\n    breadcrumb: {\n        id: string,\n        label: string\n    }[],\n    path: string,\n    selection: FSDescriptor[],\n    viewMode: \"grid\" | \"list\",\n    historyIndex: number,\n    history: string[],\n    sidebarItems: FSDescriptor[],\n    sortOrder: FileSorting\n}\n\n// TODO: replace http configs\ntype HttpConfiguration = (\n    { url: string } |\n    { urlTemplate: (path: string) => string }\n) & {\n    method?: \"get\" | \"put\" | \"post\" | \"patch\" | \"delete\",\n    headers?: { [key: string]: string }\n}\n\nexport type NgxFileManagerConfiguration = Partial<{\n    /**\n     * Initial path\n     */\n    path: string,\n\n    /**\n     * Custom root path (will appear as '/').\n     * Defaults to '/'.\n     *\n     * User cannot view outside of this path.\n     *   (Not to be used as a security measure!)\n     */\n    chrootPath: string,\n\n    /**\n     * Restrict users to only navigate around to subpaths of the specified `path`\n     */\n    navigateOnlyToDescendants: boolean,\n    showBreadcrumb: boolean,\n    showTreeview: boolean,\n\n    /**\n     * Name of the \"root\" path `/`\n     * Defaults to \"Storage\"\n     */\n    rootName: string,\n\n    /**\n     * Maximum number of items to be stored in history.\n     */\n    maxHistoryLength: number,\n\n    apiSettings: {\n        listEntriesUrl?: string,\n        listEntriesUrlTemplate?: (path: string) => string,\n        downloadEntryUrl?: string,\n        downloadEntryUrlTemplate?: (path: string) => string,\n        uploadEntryUrl?: string,\n        uploadEntryUrlTemplate?: (path: string) => string,\n        deleteEntryUrl?: string,\n        deleteEntryUrlTemplate?: (path: string) => string,\n        renameEntryUrl?: string,\n        renameEntryUrlTemplate?: (path: string) => string,\n        createDirectoryUrl?: string,\n        createDirectoryUrlTemplate?: (path: string) => string\n    },\n\n    /**\n     * The path that images are loaded from.\n     * Default value `/assets/dotglitch/webcomponents/`\n     */\n    assetPath: string,\n    sidebarLocationStrategy: \"known\" | \"currentDirectory\",\n\n    iconResolver: (file: FSDescriptor) => string,\n\n    imageSize: \"normal\" | \"small\" | \"huge\",\n\n    /**\n     *\n     */\n    selectionMode: \"single\" | \"multiple\",\n\n    /**\n     * This determines if the filemanager shows selected entries\n     *\n     * If set to `focusFiles`, file paths that match from the provided `focusedFiles`\n     * will be highlighted, and can be selected / deselected.\n     */\n    mode: \"focusFiles\" | \"normal\",\n    focusedFiles: string[]\n}>\n\n@Component({\n    selector: 'app-filemanager',\n    templateUrl: './filemanager.component.html',\n    styleUrls: ['./filemanager.component.scss'],\n    imports: [\n        NgIf,\n        NgForOf,\n        AngularSplitModule,\n        FileGridComponent,\n        MatTabsModule,\n        MatIconModule,\n        MatSidenavModule,\n        ToolbarComponent,\n        TreeViewComponent\n    ],\n    standalone: true\n})\nexport class FilemanagerComponent implements OnInit {\n    @ViewChild('tabGroup') tabGroup: MatTabGroup;\n    @ViewChildren(FileGridComponent) fileGrids: QueryList<FileGridComponent>;\n    @ViewChild(TreeViewComponent) treeView: TreeViewComponent;\n    @ViewChild(ToolbarComponent) toolbar: ToolbarComponent;\n    @ViewChild(MatDrawerContainer) drawer: MatDrawerContainer;\n\n    @Input() config: NgxFileManagerConfiguration = {\n        apiSettings: {\n            listEntriesUrl: `/api/filesystem/`,\n            uploadEntryUrl: `/api/filesystem/`,\n            downloadEntryUrl: `/api/filesystem/`,\n            deleteEntryUrl: `/api/filesystem/`,\n            createDirectoryUrl: `/api/filesystem/folder`,\n            renameEntryUrl: `/api/filesystem/rename`\n        }\n    };\n\n    @Input() gridSize: \"small\" | \"normal\" | \"large\" = \"normal\";\n    @Input() mode: \"grid\" | \"list\";\n    @Input() contextTags: {[key: string]: string};\n\n\n    @Input() value: FSDescriptor[] = [];\n    @Output() valueChange = new EventEmitter<FSDescriptor[]>();\n\n    gridValues: FSDescriptor[][] = [];\n\n    /**\n     * Emits when focused files change.\n     * Only available in `focusFiles` mode.\n     */\n    @Output() focusedFilesChange = new EventEmitter();\n    /**\n     * Emits when a file is uploaded.\n     */\n    @Output() fileUpload = new EventEmitter();\n    /**\n     * Emits when a file is downloaded.\n     */\n    @Output() fileDownload = new EventEmitter();\n    @Output() fileRename = new EventEmitter();\n    @Output() fileDelete = new EventEmitter();\n    @Output() fileCopy = new EventEmitter();\n    @Output() filePaste = new EventEmitter();\n\n    @Output() fileSelect = new EventEmitter<FileDescriptor>();\n    @Output() fileDblClick = new EventEmitter<FileDescriptor>();\n    @Output() folderSelect = new EventEmitter<DirectoryDescriptor>();\n    @Output() folderDblClick = new EventEmitter<DirectoryDescriptor>();\n\n    /**\n     * Emits when multiple file selections change.\n     */\n    @Output() filesSelect = new EventEmitter<FSDescriptor[]>();\n    /**\n     * Emits when any selection changes, single or multiple files.\n     */\n    // @Output() selectionChange = new EventEmitter<FSDescriptor[]>();\n\n    showHiddenFiles = false;\n    showSidebar = true;\n    sidebarOverlay = false;\n    width = 0;\n\n    isHomeAncestor = false;\n\n    currentTab: FileViewTab = {} as any;\n    get currentFileGrid() { return this.fileGrids.get(this.tabIndex) }\n    tabIndex = 0;\n    tabs: FileViewTab[] = [];\n\n    iconResolver: IconResolver;\n\n    constructor (\n        @Optional() @Inject(NGX_WEB_COMPONENTS_CONFIG) readonly libConfig: NgxWebComponentsConfig = {},\n        private readonly lazyLoader: LazyLoaderService,\n        private viewContainer: ViewContainerRef,\n        private fetch: Fetch\n    ) {\n        lazyLoader.registerComponent({\n            id: \"folder-rename\",\n            group: \"@dotglitch/ngx-web-components\",\n            load: () => import('./folder-rename/folder-rename.component')\n        })\n\n        this.iconResolver = new IconResolver(libConfig.assetPath);\n    }\n\n    ngOnInit(): void {\n        this.initTab(this.config.path);\n        this.currentTab = this.tabs[0];\n    }\n\n    ngAfterViewInit() {\n        this.onResize();\n\n        setTimeout(() => this.onResize(), 250);\n    }\n\n    onTreeViewLoadChildren({item, cb}) {\n        const url = this.config.apiSettings.listEntriesUrlTemplate\n                  ? this.config.apiSettings.listEntriesUrlTemplate(item.path + item.name)\n                  : this.config.apiSettings.listEntriesUrl\n\n        this.fetch.post(url, { path: item.path + item.name, showHidden: this.showHiddenFiles })\n            .then((data: any) => {\n                const dirs: DirectoryDescriptor[] = data.dirs;\n                cb(dirs);\n            })\n    }\n\n    initTab(path: string) {\n        this.tabs.push(this.currentTab = {\n            id: ulid(),\n            label: this.getTabLabel(path),\n            breadcrumb: this.calcBreadcrumb(path),\n            path,\n            selection: [],\n            viewMode: this.mode || 'grid',\n            historyIndex: 0,\n            history: [],\n            sidebarItems: [],\n            sortOrder: 'a-z'\n        });\n        this.tabIndex = this.tabs.length;\n    }\n\n    closeTab(tab: FileViewTab) {\n        this.tabs.splice(this.tabs.findIndex(t => t.id == tab.id), 1);\n    }\n\n    calcBreadcrumb(path: string) {\n        if (!path) return null;\n\n        path = path.replace(\"#/\", '/');\n\n        // If we're acting like we're in a changed root, we wipe out\n        // breadcrumbs below the root\n        if (this.config.chrootPath) {\n            path = path.replace(this.config.chrootPath, '');\n            const parts = path.split('/');\n\n            path = path.replace(/^\\//, this.config.chrootPath);\n            return parts.map((p, i) => {\n                const path = parts.slice(0, i + 1).join('/');\n\n                return {\n                    id: (this.config.chrootPath + (path || '/')).replace(/\\/+/g, '/'),\n                    label: p || \"\"\n                };\n            });\n        }\n        else {\n            const parts = path.split('/');\n\n            return parts.map((p, i) => {\n                const path = parts.slice(0, i + 1).join('/');\n\n                return {\n                    id: path || '/',\n                    label: p || \"\"\n                };\n            });\n        }\n    }\n\n    onBreadcrumbClick(crumb) {\n        if (crumb.id) {\n            this.currentTab.path = crumb.id;\n            this.currentTab.breadcrumb = this.calcBreadcrumb(crumb.id);\n        }\n    }\n\n    onTabPathChange(tab: FileViewTab) {\n        tab.label = this.getTabLabel(tab.path);\n        tab.breadcrumb = this.calcBreadcrumb(tab.path);\n\n        tab.historyIndex++;\n        tab.history.push(tab.path);\n        tab.history.splice(typeof this.config.maxHistoryLength == 'number' ? this.config.maxHistoryLength : 50);\n    }\n\n    onTreeViewSelect(item: FSDescriptor) {\n        this.currentTab.path = item.path + item.name;\n    }\n\n    onTabLoadFiles(tab: FileViewTab, files: FSDescriptor[]) {\n        if (tab.sidebarItems.length == 0) {\n            tab.sidebarItems = files.filter(f => f.kind == \"directory\");\n            return;\n        }\n\n        const currentItems = tab.sidebarItems;\n        const dirItems = files.filter(f => f.kind == \"directory\");\n\n        function recurse(items) {\n            return items.find(i => tab.path?.startsWith(i.path));\n        }\n        const target = recurse(currentItems);\n\n        if (target)\n            target['_children'] = dirItems;\n\n        tab.sidebarItems = currentItems;\n    }\n\n    onGridValueChange() {\n        this.value = this.gridValues.flat(1);\n        this.valueChange.emit(this.value)\n    }\n\n    getTabLabel(path: string) {\n        return path?.split('/').filter(p => p).pop();\n    }\n\n    async onResize() {\n        // Trigger re-calculation of the view\n        this.fileGrids.forEach(g => g.resize());\n\n        const el = this.viewContainer.element.nativeElement as HTMLElement;\n        const bounds = el.getBoundingClientRect();\n        this.width = bounds.width;\n\n        // If the view area is less than 650px wide, use overlay the sidebar panel\n        this.sidebarOverlay = bounds.width < 650;\n        if (this.sidebarOverlay == false && [...this.drawer._drawers][0].opened) {\n            this.drawer.close();\n        }\n    }\n\n    async onResizeEnd() {\n        this.onResize();\n\n        setTimeout(() => this.onResize(), 250);\n    }\n\n    getSelection() {\n        if (this.currentTab.viewMode == \"grid\") {\n            return this.currentTab.selection\n        }\n        else {\n            return this.value;\n        }\n    }\n\n    clearSelection() {\n        this.fileGrids.forEach(g => g.clearSelection());\n    }\n\n    // Tell the child grid to refresh it's sorting\n    refreshSorting() {\n        this.fileGrids.forEach(g => g.sort());\n    }\n\n    refreshData() {\n        this.fileGrids.forEach(g => g.loadFolder());\n    }\n\n    getFileData(file: FileDescriptor) {\n        let url = this.config.apiSettings.renameEntryUrlTemplate\n            ? this.config.apiSettings.renameEntryUrlTemplate(file.path + file.name)\n            : this.config.apiSettings.renameEntryUrl;\n\n        url = (url.includes('?') ? '&' : '?') + `dir=${file.path}&file=${file.name}`;\n\n        return url;\n    }\n\n    downloadFile(file: FSDescriptor) {\n        let path = file.path + file.name;\n        if (file.kind == \"directory\" && !path.endsWith('/'))\n            path += \"/\";\n\n        const url = this.config.apiSettings.downloadEntryUrlTemplate\n            ? this.config.apiSettings.downloadEntryUrlTemplate(path)\n            : this.config.apiSettings.downloadEntryUrl;\n\n        // window.open(target);\n        var link = document.createElement(\"a\");\n        link.download = file.name;\n        link.href = url;\n        link.click();\n        link.remove();\n        this.fileDownload.next(file);\n    }\n}\n","<app-toolbar\n    [currentTab]=\"currentTab\"\n    [(showHiddenFiles)]=\"showHiddenFiles\"\n    [(showSidebar)]=\"showSidebar\"\n    [config]=\"config\"\n    [showBareMinimum]=\"width < 500 && config.showBreadcrumb != false\"\n    (onBreadcrumbClick)=\"onBreadcrumbClick($event)\"\n/>\n\n<mat-drawer-container>\n    <mat-drawer #drawer mode=\"over\">\n        <app-toolbar\n            *ngIf=\"width < 500 && config.showBreadcrumb != false\"\n            [currentTab]=\"currentTab\"\n            [(showHiddenFiles)]=\"showHiddenFiles\"\n            [(showSidebar)]=\"showSidebar\"\n            [config]=\"config\"\n            [drawerMode]=\"true\"\n            (onBreadcrumbClick)=\"onBreadcrumbClick($event)\"\n        />\n        <app-tree-view\n            [data]=\"currentTab.sidebarItems\"\n            (loadChildren)=\"onTreeViewLoadChildren($event)\"\n            (click)=\"onTreeViewSelect($event)\"\n        />\n    </mat-drawer>\n    <mat-drawer-content>\n        <as-split direction=\"horizontal\" [gutterSize]=\"sidebarOverlay ? 0 : 2\" [unit]=\"'pixel'\" (dragEnd)=\"onResizeEnd()\">\n            <as-split-area\n                style=\"background-color: var(--filemanager-sidebar-background-color, #2c2c2c)\"\n                [size]=\"215\"\n                [minSize]=\"215\"\n                [maxSize]=\"width/4\"\n                [visible]=\"!sidebarOverlay && config.showTreeview != false\"\n            >\n                <div class=\"sidebar\"\n                    *ngIf=\"!sidebarOverlay && config.showTreeview != false\"\n                    (click)=\"currentTab.selection = []\"\n                >\n                    <app-tree-view\n                        [data]=\"currentTab.sidebarItems\"\n                        (loadChildren)=\"onTreeViewLoadChildren($event)\"\n                        (click)=\"onTreeViewSelect($event)\"\n                    />\n                </div>\n            </as-split-area>\n            <as-split-area style=\"background-color: var(--filemanager-background-color, #272727);\">\n                <div class=\"content\"\n                    [style.--tab-height]=\"tabs.length > 1 ? '36px' : '0'\"\n                >\n                    <mat-tab-group #tabGroup (selectedTabChange)=\"currentTab = tabs[$event.index]\" [(selectedIndex)]=\"tabIndex\">\n                        <mat-tab *ngFor=\"let tab of tabs; let i = index\">\n                            <ng-template mat-tab-label>\n                                {{tab.label}}\n                                <mat-icon\n                                    class=\"close\"\n                                    (click)=\"closeTab(tab)\">\n                                    close\n                                </mat-icon>\n                            </ng-template>\n\n                            <ng-template matTabContent>\n                                <app-file-grid\n                                    [viewMode]=\"tab.viewMode\"\n                                    [tab]=\"tab\"\n                                    [config]=\"config\"\n                                    [gridSize]=\"gridSize\"\n                                    [sortOrder]=\"tab.sortOrder\"\n                                    [(selection)]=\"tab.selection\"\n                                    [(path)]=\"tab.path\"\n                                    (pathChange)=\"onTabPathChange(tab)\"\n                                    [(value)]=\"gridValues[i]\"\n                                    (valueChange)=\"onGridValueChange()\"\n                                    (loadFiles)=\"onTabLoadFiles(tab, $event)\"\n\n                                    (fileSelect)=\"fileSelect.next($event)\"\n                                    (fileDblClick)=\"fileDblClick.next($event)\"\n                                    (folderSelect)=\"folderSelect.next($event)\"\n                                    (folderDblClick)=\"folderDblClick.next($event)\"\n                                />\n                            </ng-template>\n                        </mat-tab>\n                    </mat-tab-group>\n                </div>\n            </as-split-area>\n        </as-split>\n    </mat-drawer-content>\n</mat-drawer-container>\n\n"]}
|
|
@@ -10466,9 +10466,9 @@ class FilemanagerComponent {
|
|
|
10466
10466
|
let path = file.path + file.name;
|
|
10467
10467
|
if (file.kind == "directory" && !path.endsWith('/'))
|
|
10468
10468
|
path += "/";
|
|
10469
|
-
const url = this.config.apiSettings.
|
|
10470
|
-
? this.config.apiSettings.
|
|
10471
|
-
: this.config.apiSettings.
|
|
10469
|
+
const url = this.config.apiSettings.downloadEntryUrlTemplate
|
|
10470
|
+
? this.config.apiSettings.downloadEntryUrlTemplate(path)
|
|
10471
|
+
: this.config.apiSettings.downloadEntryUrl;
|
|
10472
10472
|
// window.open(target);
|
|
10473
10473
|
var link = document.createElement("a");
|
|
10474
10474
|
link.download = file.name;
|