@yuuvis/app-drive 0.7.3
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.
- package/README.md +47 -0
- package/esm2022/extensions/index.mjs +2 -0
- package/esm2022/extensions/lib/extensions.module.mjs +35 -0
- package/esm2022/extensions/lib/extensions.service.mjs +44 -0
- package/esm2022/extensions/lib/object-config.defaults.mjs +19 -0
- package/esm2022/extensions/yuuvis-app-drive-extensions.mjs +5 -0
- package/esm2022/index.mjs +5 -0
- package/esm2022/lib/actions/copy-link/copy-link.action.mjs +40 -0
- package/esm2022/lib/actions/index.mjs +7 -0
- package/esm2022/lib/actions/manage-versions/manage-versions.action.mjs +33 -0
- package/esm2022/lib/actions/manage-versions/manage-versions.component.mjs +105 -0
- package/esm2022/lib/actions/paste/paste.action.mjs +41 -0
- package/esm2022/lib/actions/rename/rename.action.mjs +31 -0
- package/esm2022/lib/actions/rename/rename.component.mjs +42 -0
- package/esm2022/lib/actions/rename/rename.validator.mjs +23 -0
- package/esm2022/lib/actions/updateContent/update.content.action.mjs +52 -0
- package/esm2022/lib/components/add-button/add-button-overlay/add-button-overlay.component.mjs +109 -0
- package/esm2022/lib/components/add-button/add-button.component.mjs +39 -0
- package/esm2022/lib/components/breadcrumb/breadcrumb.component.mjs +74 -0
- package/esm2022/lib/components/folder-tree/folder-tree.component.mjs +89 -0
- package/esm2022/lib/components/index.mjs +10 -0
- package/esm2022/lib/components/object-name/object-name.component.mjs +60 -0
- package/esm2022/lib/components/overlay/create-folder/create-folder.component.mjs +48 -0
- package/esm2022/lib/components/paste-from-clipboard/paste-from-clipboard.component.mjs +28 -0
- package/esm2022/lib/components/ribbon/ribbon.component.mjs +102 -0
- package/esm2022/lib/components/search-filter/date-range-picker/date-range-picker.component.mjs +38 -0
- package/esm2022/lib/components/search-filter/search-filter.component.mjs +429 -0
- package/esm2022/lib/components/sort/sort.component.mjs +156 -0
- package/esm2022/lib/components/versions-list/tile/tile.component.mjs +60 -0
- package/esm2022/lib/components/versions-list/versions-list.component.mjs +94 -0
- package/esm2022/lib/container/drive/drive.component.mjs +116 -0
- package/esm2022/lib/drive.icons.mjs +16 -0
- package/esm2022/lib/drive.schema.mjs +49 -0
- package/esm2022/lib/lib.routes.mjs +17 -0
- package/esm2022/lib/pages/files/files.component.mjs +377 -0
- package/esm2022/lib/pages/object/object.component.mjs +200 -0
- package/esm2022/lib/services/drive/drive.interface.mjs +14 -0
- package/esm2022/lib/services/drive/drive.service.mjs +437 -0
- package/esm2022/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.component.mjs +158 -0
- package/esm2022/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.interface.mjs +2 -0
- package/esm2022/lib/services/drive/versions/versions.mapping.mjs +42 -0
- package/esm2022/lib/services/index.mjs +5 -0
- package/esm2022/lib/services/providers/drive.providers.mjs +10 -0
- package/esm2022/lib/services/resolver/files.resolver.mjs +12 -0
- package/esm2022/lib/services/resolver/index.mjs +3 -0
- package/esm2022/lib/services/resolver/versions.route.resolver.mjs +10 -0
- package/esm2022/lib/services/stored-query/stored-query.data.mjs +25 -0
- package/esm2022/lib/services/stored-query/stored-query.interface.mjs +2 -0
- package/esm2022/lib/services/stored-query/stored-query.service.mjs +41 -0
- package/esm2022/lib/services/tokens/breadcrumb-max-depth.token.mjs +3 -0
- package/esm2022/lib/services/tokens/index.mjs +2 -0
- package/esm2022/yuuvis-app-drive.mjs +5 -0
- package/extensions/README.md +3 -0
- package/extensions/index.d.ts +1 -0
- package/extensions/lib/extensions.module.d.ts +6 -0
- package/extensions/lib/extensions.service.d.ts +7 -0
- package/extensions/lib/object-config.defaults.d.ts +2 -0
- package/fesm2022/yuuvis-app-drive-extensions.mjs +99 -0
- package/fesm2022/yuuvis-app-drive-extensions.mjs.map +1 -0
- package/fesm2022/yuuvis-app-drive.mjs +2945 -0
- package/fesm2022/yuuvis-app-drive.mjs.map +1 -0
- package/index.d.ts +4 -0
- package/lib/actions/copy-link/copy-link.action.d.ts +18 -0
- package/lib/actions/index.d.ts +6 -0
- package/lib/actions/manage-versions/manage-versions.action.d.ts +17 -0
- package/lib/actions/manage-versions/manage-versions.component.d.ts +32 -0
- package/lib/actions/paste/paste.action.d.ts +17 -0
- package/lib/actions/rename/rename.action.d.ts +17 -0
- package/lib/actions/rename/rename.component.d.ts +12 -0
- package/lib/actions/rename/rename.validator.d.ts +5 -0
- package/lib/actions/updateContent/update.content.action.d.ts +18 -0
- package/lib/components/add-button/add-button-overlay/add-button-overlay.component.d.ts +26 -0
- package/lib/components/add-button/add-button.component.d.ts +12 -0
- package/lib/components/breadcrumb/breadcrumb.component.d.ts +25 -0
- package/lib/components/folder-tree/folder-tree.component.d.ts +13 -0
- package/lib/components/index.d.ts +8 -0
- package/lib/components/object-name/object-name.component.d.ts +21 -0
- package/lib/components/overlay/create-folder/create-folder.component.d.ts +12 -0
- package/lib/components/paste-from-clipboard/paste-from-clipboard.component.d.ts +13 -0
- package/lib/components/ribbon/ribbon.component.d.ts +24 -0
- package/lib/components/search-filter/date-range-picker/date-range-picker.component.d.ts +13 -0
- package/lib/components/search-filter/search-filter.component.d.ts +23 -0
- package/lib/components/sort/sort.component.d.ts +31 -0
- package/lib/components/versions-list/tile/tile.component.d.ts +14 -0
- package/lib/components/versions-list/versions-list.component.d.ts +17 -0
- package/lib/container/drive/drive.component.d.ts +36 -0
- package/lib/drive.icons.d.ts +15 -0
- package/lib/drive.schema.d.ts +23 -0
- package/lib/lib.routes.d.ts +2 -0
- package/lib/pages/files/files.component.d.ts +101 -0
- package/lib/pages/object/object.component.d.ts +35 -0
- package/lib/services/drive/drive.interface.d.ts +62 -0
- package/lib/services/drive/drive.service.d.ts +64 -0
- package/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.component.d.ts +31 -0
- package/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.interface.d.ts +8 -0
- package/lib/services/drive/versions/versions.mapping.d.ts +2 -0
- package/lib/services/index.d.ts +4 -0
- package/lib/services/providers/drive.providers.d.ts +7 -0
- package/lib/services/resolver/files.resolver.d.ts +2 -0
- package/lib/services/resolver/index.d.ts +2 -0
- package/lib/services/resolver/versions.route.resolver.d.ts +2 -0
- package/lib/services/stored-query/stored-query.data.d.ts +5 -0
- package/lib/services/stored-query/stored-query.interface.d.ts +5 -0
- package/lib/services/stored-query/stored-query.service.d.ts +10 -0
- package/lib/services/tokens/breadcrumb-max-depth.token.d.ts +2 -0
- package/lib/services/tokens/index.d.ts +1 -0
- package/package.json +41 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
// Mapping schema for this apps backend schema
|
|
2
|
+
import { SystemType } from '@yuuvis/client-core';
|
|
3
|
+
// eslint-disable-next-line @nx/enforce-module-boundaries
|
|
4
|
+
import { marker } from '@colsen1991/ngx-translate-extract-marker';
|
|
5
|
+
import { APP_DRIVE_ICONS } from './drive.icons';
|
|
6
|
+
// use marker to extract the labels for the app schema types
|
|
7
|
+
// make sure to provide a marker for each type/flavor ID
|
|
8
|
+
marker('io.yuuvis.app.drive.folder');
|
|
9
|
+
marker('io.yuuvis.app.drive.file');
|
|
10
|
+
export const FS_PROPERTIES = {
|
|
11
|
+
name: 'appOsdrive:fileName'
|
|
12
|
+
};
|
|
13
|
+
export const FS_SOTS = {
|
|
14
|
+
object: 'appOsdrive:file'
|
|
15
|
+
};
|
|
16
|
+
export const APP_PREFIX = 'appDrive:';
|
|
17
|
+
export const APP_ID = 'io.yuuvis.app.drive';
|
|
18
|
+
export const APP_SCHEMA = {
|
|
19
|
+
id: APP_ID,
|
|
20
|
+
name: 'OS Drive',
|
|
21
|
+
icon: '<svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 -960 960 960" width="24"><path d="M340-320h300q50 0 85-35t35-85q0-50-35-85t-85-35q-8-58-53-99t-101-41q-51 0-92.5 26T332-600q-57 5-94.5 43.5T200-460q0 58 41 99t99 41Zm0-80q-25 0-42.5-17.5T280-460q0-25 17.5-42.5T340-520h60v-20q0-33 23.5-56.5T480-620q33 0 56.5 23.5T560-540v60h80q17 0 28.5 11.5T680-440q0 17-11.5 28.5T640-400H340ZM480-80q-83 0-156-31.5T197-197q-54-54-85.5-127T80-480q0-83 31.5-156T197-763q54-54 127-85.5T480-880q83 0 156 31.5T763-763q54 54 85.5 127T880-480q0 83-31.5 156T763-197q-54 54-127 85.5T480-80Zm0-80q134 0 227-93t93-227q0-134-93-227t-227-93q-134 0-227 93t-93 227q0 134 93 227t227 93Zm0-320Z"/></svg>',
|
|
22
|
+
types: {
|
|
23
|
+
folder: {
|
|
24
|
+
id: `${APP_ID}.folder`,
|
|
25
|
+
icon: APP_DRIVE_ICONS.folder,
|
|
26
|
+
objectType: SystemType.FOLDER,
|
|
27
|
+
sots: [FS_SOTS.object]
|
|
28
|
+
},
|
|
29
|
+
file: {
|
|
30
|
+
id: `${APP_ID}.file`,
|
|
31
|
+
icon: APP_DRIVE_ICONS.file,
|
|
32
|
+
objectType: SystemType.DOCUMENT,
|
|
33
|
+
sots: [FS_SOTS.object]
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
flavors: []
|
|
37
|
+
};
|
|
38
|
+
export const APP_ACTIONS = {
|
|
39
|
+
rename: 'app.drive.action.rename',
|
|
40
|
+
paste: 'app.drive.action.paste',
|
|
41
|
+
copyLink: 'app.drive.action.copy.link',
|
|
42
|
+
contentUpdate: 'app.drive.action.content.update',
|
|
43
|
+
manageVersions: 'app.drive.action.manage-versions'
|
|
44
|
+
};
|
|
45
|
+
export const ACTION_CONTEXT = {
|
|
46
|
+
subjectProperty: FS_PROPERTIES.name,
|
|
47
|
+
appId: APP_ID
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJpdmUuc2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hcHBzL2RyaXZlL3NyYy9saWIvZHJpdmUuc2NoZW1hLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDhDQUE4QztBQUU5QyxPQUFPLEVBQUUsVUFBVSxFQUFxQixNQUFNLHFCQUFxQixDQUFDO0FBRXBFLHlEQUF5RDtBQUN6RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUdoRCw0REFBNEQ7QUFDNUQsd0RBQXdEO0FBQ3hELE1BQU0sQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO0FBQ3JDLE1BQU0sQ0FBQywwQkFBMEIsQ0FBQyxDQUFDO0FBRW5DLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRztJQUMzQixJQUFJLEVBQUUscUJBQXFCO0NBQzVCLENBQUM7QUFDRixNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUc7SUFDckIsTUFBTSxFQUFFLGlCQUFpQjtDQUMxQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQztBQUN0QyxNQUFNLENBQUMsTUFBTSxNQUFNLEdBQUcscUJBQXFCLENBQUM7QUFFNUMsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFzRTtJQUMzRixFQUFFLEVBQUUsTUFBTTtJQUNWLElBQUksRUFBRSxVQUFVO0lBQ2hCLElBQUksRUFBRSw4cUJBQThxQjtJQUNwckIsS0FBSyxFQUFFO1FBQ0wsTUFBTSxFQUFFO1lBQ04sRUFBRSxFQUFFLEdBQUcsTUFBTSxTQUFTO1lBQ3RCLElBQUksRUFBRSxlQUFlLENBQUMsTUFBTTtZQUM1QixVQUFVLEVBQUUsVUFBVSxDQUFDLE1BQU07WUFDN0IsSUFBSSxFQUFFLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztTQUN2QjtRQUNELElBQUksRUFBRTtZQUNKLEVBQUUsRUFBRSxHQUFHLE1BQU0sT0FBTztZQUNwQixJQUFJLEVBQUUsZUFBZSxDQUFDLElBQUk7WUFDMUIsVUFBVSxFQUFFLFVBQVUsQ0FBQyxRQUFRO1lBQy9CLElBQUksRUFBRSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7U0FDdkI7S0FDRjtJQUNELE9BQU8sRUFBRSxFQUFFO0NBQ1osQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRztJQUN6QixNQUFNLEVBQUUseUJBQXlCO0lBQ2pDLEtBQUssRUFBRSx3QkFBd0I7SUFDL0IsUUFBUSxFQUFFLDRCQUE0QjtJQUN0QyxhQUFhLEVBQUUsaUNBQWlDO0lBQ2hELGNBQWMsRUFBRSxrQ0FBa0M7Q0FDbkQsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBa0I7SUFDM0MsZUFBZSxFQUFFLGFBQWEsQ0FBQyxJQUFJO0lBQ25DLEtBQUssRUFBRSxNQUFNO0NBQ2QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIE1hcHBpbmcgc2NoZW1hIGZvciB0aGlzIGFwcHMgYmFja2VuZCBzY2hlbWFcblxuaW1wb3J0IHsgU3lzdGVtVHlwZSwgVmlydHVhbE9iamVjdFR5cGUgfSBmcm9tICdAeXV1dmlzL2NsaWVudC1jb3JlJztcbmltcG9ydCB7IEFwcFNjaGVtYSB9IGZyb20gJ0B5dXV2aXMvY2xpZW50LXNoZWxsLWNvcmUnO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBueC9lbmZvcmNlLW1vZHVsZS1ib3VuZGFyaWVzXG5pbXBvcnQgeyBtYXJrZXIgfSBmcm9tICdAY29sc2VuMTk5MS9uZ3gtdHJhbnNsYXRlLWV4dHJhY3QtbWFya2VyJztcbmltcG9ydCB7IEFQUF9EUklWRV9JQ09OUyB9IGZyb20gJy4vZHJpdmUuaWNvbnMnO1xuaW1wb3J0IHsgQWN0aW9uQ29udGV4dCB9IGZyb20gJ0B5dXV2aXMvY2xpZW50LWZyYW1ld29yay9hY3Rpb25zJztcblxuLy8gdXNlIG1hcmtlciB0byBleHRyYWN0IHRoZSBsYWJlbHMgZm9yIHRoZSBhcHAgc2NoZW1hIHR5cGVzXG4vLyBtYWtlIHN1cmUgdG8gcHJvdmlkZSBhIG1hcmtlciBmb3IgZWFjaCB0eXBlL2ZsYXZvciBJRFxubWFya2VyKCdpby55dXV2aXMuYXBwLmRyaXZlLmZvbGRlcicpO1xubWFya2VyKCdpby55dXV2aXMuYXBwLmRyaXZlLmZpbGUnKTtcblxuZXhwb3J0IGNvbnN0IEZTX1BST1BFUlRJRVMgPSB7XG4gIG5hbWU6ICdhcHBPc2RyaXZlOmZpbGVOYW1lJ1xufTtcbmV4cG9ydCBjb25zdCBGU19TT1RTID0ge1xuICBvYmplY3Q6ICdhcHBPc2RyaXZlOmZpbGUnXG59O1xuXG5leHBvcnQgY29uc3QgQVBQX1BSRUZJWCA9ICdhcHBEcml2ZTonO1xuZXhwb3J0IGNvbnN0IEFQUF9JRCA9ICdpby55dXV2aXMuYXBwLmRyaXZlJztcblxuZXhwb3J0IGNvbnN0IEFQUF9TQ0hFTUE6IEFwcFNjaGVtYTx7IGZvbGRlcjogVmlydHVhbE9iamVjdFR5cGU7IGZpbGU6IFZpcnR1YWxPYmplY3RUeXBlIH0+ID0ge1xuICBpZDogQVBQX0lELFxuICBuYW1lOiAnT1MgRHJpdmUnLFxuICBpY29uOiAnPHN2ZyB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCIgaGVpZ2h0PVwiMjRcIiB2aWV3Qm94PVwiMCAtOTYwIDk2MCA5NjBcIiB3aWR0aD1cIjI0XCI+PHBhdGggZD1cIk0zNDAtMzIwaDMwMHE1MCAwIDg1LTM1dDM1LTg1cTAtNTAtMzUtODV0LTg1LTM1cS04LTU4LTUzLTk5dC0xMDEtNDFxLTUxIDAtOTIuNSAyNlQzMzItNjAwcS01NyA1LTk0LjUgNDMuNVQyMDAtNDYwcTAgNTggNDEgOTl0OTkgNDFabTAtODBxLTI1IDAtNDIuNS0xNy41VDI4MC00NjBxMC0yNSAxNy41LTQyLjVUMzQwLTUyMGg2MHYtMjBxMC0zMyAyMy41LTU2LjVUNDgwLTYyMHEzMyAwIDU2LjUgMjMuNVQ1NjAtNTQwdjYwaDgwcTE3IDAgMjguNSAxMS41VDY4MC00NDBxMCAxNy0xMS41IDI4LjVUNjQwLTQwMEgzNDBaTTQ4MC04MHEtODMgMC0xNTYtMzEuNVQxOTctMTk3cS01NC01NC04NS41LTEyN1Q4MC00ODBxMC04MyAzMS41LTE1NlQxOTctNzYzcTU0LTU0IDEyNy04NS41VDQ4MC04ODBxODMgMCAxNTYgMzEuNVQ3NjMtNzYzcTU0IDU0IDg1LjUgMTI3VDg4MC00ODBxMCA4My0zMS41IDE1NlQ3NjMtMTk3cS01NCA1NC0xMjcgODUuNVQ0ODAtODBabTAtODBxMTM0IDAgMjI3LTkzdDkzLTIyN3EwLTEzNC05My0yMjd0LTIyNy05M3EtMTM0IDAtMjI3IDkzdC05MyAyMjdxMCAxMzQgOTMgMjI3dDIyNyA5M1ptMC0zMjBaXCIvPjwvc3ZnPicsXG4gIHR5cGVzOiB7XG4gICAgZm9sZGVyOiB7XG4gICAgICBpZDogYCR7QVBQX0lEfS5mb2xkZXJgLFxuICAgICAgaWNvbjogQVBQX0RSSVZFX0lDT05TLmZvbGRlcixcbiAgICAgIG9iamVjdFR5cGU6IFN5c3RlbVR5cGUuRk9MREVSLFxuICAgICAgc290czogW0ZTX1NPVFMub2JqZWN0XVxuICAgIH0sXG4gICAgZmlsZToge1xuICAgICAgaWQ6IGAke0FQUF9JRH0uZmlsZWAsXG4gICAgICBpY29uOiBBUFBfRFJJVkVfSUNPTlMuZmlsZSxcbiAgICAgIG9iamVjdFR5cGU6IFN5c3RlbVR5cGUuRE9DVU1FTlQsXG4gICAgICBzb3RzOiBbRlNfU09UUy5vYmplY3RdXG4gICAgfVxuICB9LFxuICBmbGF2b3JzOiBbXVxufTtcblxuZXhwb3J0IGNvbnN0IEFQUF9BQ1RJT05TID0ge1xuICByZW5hbWU6ICdhcHAuZHJpdmUuYWN0aW9uLnJlbmFtZScsXG4gIHBhc3RlOiAnYXBwLmRyaXZlLmFjdGlvbi5wYXN0ZScsXG4gIGNvcHlMaW5rOiAnYXBwLmRyaXZlLmFjdGlvbi5jb3B5LmxpbmsnLFxuICBjb250ZW50VXBkYXRlOiAnYXBwLmRyaXZlLmFjdGlvbi5jb250ZW50LnVwZGF0ZScsXG4gIG1hbmFnZVZlcnNpb25zOiAnYXBwLmRyaXZlLmFjdGlvbi5tYW5hZ2UtdmVyc2lvbnMnXG59O1xuXG5leHBvcnQgY29uc3QgQUNUSU9OX0NPTlRFWFQ6IEFjdGlvbkNvbnRleHQgPSB7XG4gIHN1YmplY3RQcm9wZXJ0eTogRlNfUFJPUEVSVElFUy5uYW1lLFxuICBhcHBJZDogQVBQX0lEXG59O1xuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { DriveFrameComponent } from './container/drive/drive.component';
|
|
2
|
+
import { FilesPageComponent } from './pages/files/files.component';
|
|
3
|
+
import { ObjectPageComponent } from './pages/object/object.component';
|
|
4
|
+
import { filesResolver } from './services/resolver';
|
|
5
|
+
export const YuuvisDriveRoutes = [
|
|
6
|
+
{
|
|
7
|
+
path: '',
|
|
8
|
+
component: DriveFrameComponent,
|
|
9
|
+
children: [
|
|
10
|
+
{ path: 'files', redirectTo: 'files/root' },
|
|
11
|
+
{ path: 'files/:id', component: FilesPageComponent, resolve: { filesResolver } },
|
|
12
|
+
{ path: 'object/:id', component: ObjectPageComponent },
|
|
13
|
+
{ path: '', redirectTo: 'files/root', pathMatch: 'full' }
|
|
14
|
+
]
|
|
15
|
+
}
|
|
16
|
+
];
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliLnJvdXRlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYXBwcy9kcml2ZS9zcmMvbGliL2xpYi5yb3V0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDeEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbkUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXBELE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFZO0lBQ3hDO1FBQ0UsSUFBSSxFQUFFLEVBQUU7UUFDUixTQUFTLEVBQUUsbUJBQW1CO1FBQzlCLFFBQVEsRUFBRTtZQUNSLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFO1lBQzNDLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLEVBQUUsYUFBYSxFQUFFLEVBQUU7WUFDaEYsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxtQkFBbUIsRUFBRTtZQUN0RCxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFO1NBQzFEO0tBQ0Y7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgRHJpdmVGcmFtZUNvbXBvbmVudCB9IGZyb20gJy4vY29udGFpbmVyL2RyaXZlL2RyaXZlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGaWxlc1BhZ2VDb21wb25lbnQgfSBmcm9tICcuL3BhZ2VzL2ZpbGVzL2ZpbGVzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBPYmplY3RQYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9wYWdlcy9vYmplY3Qvb2JqZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBmaWxlc1Jlc29sdmVyIH0gZnJvbSAnLi9zZXJ2aWNlcy9yZXNvbHZlcic7XG5cbmV4cG9ydCBjb25zdCBZdXV2aXNEcml2ZVJvdXRlczogUm91dGVbXSA9IFtcbiAge1xuICAgIHBhdGg6ICcnLFxuICAgIGNvbXBvbmVudDogRHJpdmVGcmFtZUNvbXBvbmVudCxcbiAgICBjaGlsZHJlbjogW1xuICAgICAgeyBwYXRoOiAnZmlsZXMnLCByZWRpcmVjdFRvOiAnZmlsZXMvcm9vdCcgfSxcbiAgICAgIHsgcGF0aDogJ2ZpbGVzLzppZCcsIGNvbXBvbmVudDogRmlsZXNQYWdlQ29tcG9uZW50LCByZXNvbHZlOiB7IGZpbGVzUmVzb2x2ZXIgfSB9LFxuICAgICAgeyBwYXRoOiAnb2JqZWN0LzppZCcsIGNvbXBvbmVudDogT2JqZWN0UGFnZUNvbXBvbmVudCB9LFxuICAgICAgeyBwYXRoOiAnJywgcmVkaXJlY3RUbzogJ2ZpbGVzL3Jvb3QnLCBwYXRoTWF0Y2g6ICdmdWxsJyB9XG4gICAgXVxuICB9XG5dO1xuIl19
|
|
@@ -0,0 +1,377 @@
|
|
|
1
|
+
import { AsyncPipe, NgClass } from '@angular/common';
|
|
2
|
+
import { Component, computed, effect, HostBinding, inject, input, signal, untracked, viewChild } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { ActivatedRoute, Router, RouterModule } from '@angular/router';
|
|
5
|
+
import { AppCacheService, BaseObjectTypeField, ClipboardService, DeviceService, DmsService, EventService, ObjectConfigService, Operator, SystemType, TranslateModule, TranslateService, YuvEventType } from '@yuuvis/client-core';
|
|
6
|
+
import { ActionsService, BASE_ACTION } from '@yuuvis/client-framework/actions';
|
|
7
|
+
import { FileDropZoneDirective } from '@yuuvis/client-framework/common';
|
|
8
|
+
import { YUV_ICONS } from '@yuuvis/client-framework/icons';
|
|
9
|
+
import { MultiObjectSummaryComponent, ObjectSummaryComponent } from '@yuuvis/client-framework/object-summary';
|
|
10
|
+
import { SimpleSearchComponent } from '@yuuvis/client-framework/simple-search';
|
|
11
|
+
import { TileConfigTriggerComponent, TileListComponent } from '@yuuvis/client-framework/tile-list';
|
|
12
|
+
import { ShellService } from '@yuuvis/client-shell-core';
|
|
13
|
+
import { ICONS, YvcIconModule } from '@yuuvis/components/icon';
|
|
14
|
+
import { SplitViewComponent, YvcSplitViewModule } from '@yuuvis/components/split-view';
|
|
15
|
+
import { finalize, map, tap } from 'rxjs';
|
|
16
|
+
import { BreadcrumbComponent, SortComponent } from '../../components';
|
|
17
|
+
import { AddButtonComponent } from '../../components/add-button/add-button.component';
|
|
18
|
+
import { FolderTreeComponent } from '../../components/folder-tree/folder-tree.component';
|
|
19
|
+
import { RibbonComponent } from '../../components/ribbon/ribbon.component';
|
|
20
|
+
import { APP_DRIVE_ICONS } from '../../drive.icons';
|
|
21
|
+
import { ACTION_CONTEXT, APP_ID, APP_SCHEMA } from '../../drive.schema';
|
|
22
|
+
import { DRIVE_EVENT, DRIVE_QUERY_FOLDER_ID, DRIVE_ROOT_FOLDER_ID } from '../../services/drive/drive.interface';
|
|
23
|
+
import { DriveService } from '../../services/drive/drive.service';
|
|
24
|
+
import { STORED_QUERY_ID_PREFIX } from '../../services/stored-query/stored-query.data';
|
|
25
|
+
import { StoredQueryService } from '../../services/stored-query/stored-query.service';
|
|
26
|
+
import { SearchFilterComponent } from '../../components/search-filter/search-filter.component';
|
|
27
|
+
import * as i0 from "@angular/core";
|
|
28
|
+
import * as i1 from "@yuuvis/components/icon";
|
|
29
|
+
import * as i2 from "@yuuvis/client-core";
|
|
30
|
+
import * as i3 from "@yuuvis/components/split-view";
|
|
31
|
+
const components = [
|
|
32
|
+
TileListComponent,
|
|
33
|
+
BreadcrumbComponent,
|
|
34
|
+
FolderTreeComponent,
|
|
35
|
+
ObjectSummaryComponent,
|
|
36
|
+
TileConfigTriggerComponent,
|
|
37
|
+
RibbonComponent,
|
|
38
|
+
AddButtonComponent,
|
|
39
|
+
SimpleSearchComponent,
|
|
40
|
+
MultiObjectSummaryComponent,
|
|
41
|
+
SortComponent,
|
|
42
|
+
SearchFilterComponent
|
|
43
|
+
];
|
|
44
|
+
const module = [YvcIconModule, TranslateModule, RouterModule, YvcSplitViewModule];
|
|
45
|
+
export class FilesPageComponent {
|
|
46
|
+
#LAYOUT_SETTINGS_STORAGE_KEY;
|
|
47
|
+
#objectConfigService;
|
|
48
|
+
#device;
|
|
49
|
+
#eventService;
|
|
50
|
+
#appCache;
|
|
51
|
+
#highlightStyles;
|
|
52
|
+
#routeIdEffect;
|
|
53
|
+
constructor() {
|
|
54
|
+
this.tileList = viewChild('tileList');
|
|
55
|
+
this.#LAYOUT_SETTINGS_STORAGE_KEY = 'yuv.app.drive.files.layout';
|
|
56
|
+
this.shellService = inject(ShellService);
|
|
57
|
+
this.dmsService = inject(DmsService);
|
|
58
|
+
this.drive = inject(DriveService);
|
|
59
|
+
this.route = inject(ActivatedRoute);
|
|
60
|
+
this.router = inject(Router);
|
|
61
|
+
this.translate = inject(TranslateService);
|
|
62
|
+
this.storedQueryService = inject(StoredQueryService);
|
|
63
|
+
this.clipboard = inject(ClipboardService);
|
|
64
|
+
this.actionsService = inject(ActionsService);
|
|
65
|
+
this.#objectConfigService = inject(ObjectConfigService);
|
|
66
|
+
this.#device = inject(DeviceService);
|
|
67
|
+
this.#eventService = inject(EventService);
|
|
68
|
+
this.ERROR_CODE = {
|
|
69
|
+
NOT_FOUND: '404',
|
|
70
|
+
// pattern: {HTTP_STATUS_CODE}-{SERVICE_ERROR_CODE}
|
|
71
|
+
INVALID_ID: '422-2912'
|
|
72
|
+
};
|
|
73
|
+
this.#appCache = inject(AppCacheService);
|
|
74
|
+
this.objectConfigBucket = APP_SCHEMA.id;
|
|
75
|
+
this.splitViewCmp = viewChild.required(SplitViewComponent);
|
|
76
|
+
this.selected = signal(undefined);
|
|
77
|
+
this.fileDropSummaryDisabled = computed(() => !this.selected()?.permissions?.writeContent);
|
|
78
|
+
this.disableCreate = false;
|
|
79
|
+
this.actions = this.drive.state$.actions;
|
|
80
|
+
this.selection = this.drive.state$.selection;
|
|
81
|
+
this.busy = this.drive.state$.busy;
|
|
82
|
+
this.flavorChips = this.shellService.getObjectFlavors();
|
|
83
|
+
this.selectionActions = computed(() => ({ selection: this.selection(), actions: this.actions() }));
|
|
84
|
+
this.emptyMode = signal(null);
|
|
85
|
+
// error code when loading the object failed. This will be used
|
|
86
|
+
// to determine a proper error message to display
|
|
87
|
+
this.error = signal(undefined);
|
|
88
|
+
this.configTypeOptions = {
|
|
89
|
+
folder: { bucket: APP_ID, type: APP_SCHEMA.types['folder'] },
|
|
90
|
+
file: { bucket: APP_ID, type: APP_SCHEMA.types['file'] }
|
|
91
|
+
};
|
|
92
|
+
this.searchFocused = false;
|
|
93
|
+
this.enableDetails = signal(true);
|
|
94
|
+
this.enableTree = signal(true);
|
|
95
|
+
this.tileConfigBucketLabel = this.translate.instant('yuv.app.drive.tile-config.bucket');
|
|
96
|
+
this.smallScreenLayout = signal(false);
|
|
97
|
+
this.sortOptionsAvailable = signal(true);
|
|
98
|
+
this.id = input(null);
|
|
99
|
+
this.highlightStyles$ = this.clipboard.clipboard$(APP_ID).pipe(takeUntilDestroyed(), map((c) => {
|
|
100
|
+
return c && c.mode && c.objects?.length
|
|
101
|
+
? [
|
|
102
|
+
{
|
|
103
|
+
cssStyles: this.#highlightStyles[c?.mode],
|
|
104
|
+
ids: c.objects.map((o) => o.id)
|
|
105
|
+
}
|
|
106
|
+
]
|
|
107
|
+
: [];
|
|
108
|
+
}));
|
|
109
|
+
this.#highlightStyles = {
|
|
110
|
+
cut: { opacity: 0.5 }
|
|
111
|
+
};
|
|
112
|
+
this.#routeIdEffect = effect(() => {
|
|
113
|
+
const param = this.id() || undefined;
|
|
114
|
+
untracked(async () => {
|
|
115
|
+
if (param === DRIVE_QUERY_FOLDER_ID) {
|
|
116
|
+
this.emptyMode.set(DRIVE_QUERY_FOLDER_ID);
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
this.emptyMode.set(param === DRIVE_ROOT_FOLDER_ID ? DRIVE_ROOT_FOLDER_ID : null);
|
|
120
|
+
this.error.set(undefined);
|
|
121
|
+
this.disableCreate = false;
|
|
122
|
+
this.currentFolderID = param;
|
|
123
|
+
this.drive.updateCurrentFolder(this.currentFolderID);
|
|
124
|
+
this.selected.set(undefined);
|
|
125
|
+
this.currentFolder = undefined;
|
|
126
|
+
if (this.currentFolderID === DRIVE_ROOT_FOLDER_ID)
|
|
127
|
+
this.currentFolderID = undefined;
|
|
128
|
+
if (this.currentFolderID) {
|
|
129
|
+
this.dmsService.getDmsObject(this.currentFolderID).subscribe({
|
|
130
|
+
next: (o) => {
|
|
131
|
+
this.currentFolder = o;
|
|
132
|
+
this._setFolderQuery(this.#getTitle(o));
|
|
133
|
+
},
|
|
134
|
+
error: (e) => {
|
|
135
|
+
console.error('Error getting folder', e);
|
|
136
|
+
this.#processLoadError(e);
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
else
|
|
141
|
+
this._setFolderQuery(this.translate.instant('yuv.app.drive.folder-tree.mydrive'));
|
|
142
|
+
});
|
|
143
|
+
});
|
|
144
|
+
this.tileListOptions = {
|
|
145
|
+
actionContext: ACTION_CONTEXT,
|
|
146
|
+
configTypes: Object.values(APP_SCHEMA.types),
|
|
147
|
+
configFlavors: [...this.shellService.getObjectFlavors(), ...APP_SCHEMA.flavors.filter((f) => !f.applicableTo).map((f) => ({ ...f, app: APP_ID }))]
|
|
148
|
+
};
|
|
149
|
+
this.query = this.drive.state$.query;
|
|
150
|
+
this.queryTitle = this.drive.state$.queryTitle;
|
|
151
|
+
this.icons = {
|
|
152
|
+
...APP_DRIVE_ICONS,
|
|
153
|
+
sort: APP_DRIVE_ICONS.sort,
|
|
154
|
+
back: YUV_ICONS.back,
|
|
155
|
+
attention: YUV_ICONS.attention,
|
|
156
|
+
refresh: YUV_ICONS.refresh,
|
|
157
|
+
clear: ICONS.clear
|
|
158
|
+
};
|
|
159
|
+
this.drive.events$.pipe(takeUntilDestroyed()).subscribe({
|
|
160
|
+
next: (e) => {
|
|
161
|
+
if (e === DRIVE_EVENT.refresh) {
|
|
162
|
+
this.refresh();
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
this.#device.screenChange$.pipe(takeUntilDestroyed()).subscribe({
|
|
167
|
+
next: (s) => {
|
|
168
|
+
this.smallScreenLayout.set(s.size === 's' && s.orientation === 'portrait');
|
|
169
|
+
this.enableDetails.set(!this.smallScreenLayout());
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
toObservable(this.drive.state$.selection)
|
|
173
|
+
.pipe(takeUntilDestroyed())
|
|
174
|
+
.subscribe({
|
|
175
|
+
next: (sel) => {
|
|
176
|
+
if (sel?.length === 0) {
|
|
177
|
+
this.tileList()?.clearSelection(true);
|
|
178
|
+
this.selected.set(undefined);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
});
|
|
182
|
+
this.route.queryParamMap.pipe(takeUntilDestroyed()).subscribe({
|
|
183
|
+
next: (p) => {
|
|
184
|
+
this.sortOptionsAvailable.set(true);
|
|
185
|
+
if (this.route.snapshot.params['id'] === DRIVE_QUERY_FOLDER_ID) {
|
|
186
|
+
const q = p.get('q');
|
|
187
|
+
this.disableCreate = true;
|
|
188
|
+
// check if the query is a stored query
|
|
189
|
+
if (q?.startsWith(STORED_QUERY_ID_PREFIX)) {
|
|
190
|
+
const sq = this.storedQueryService.getStoredQuery(q);
|
|
191
|
+
if (sq) {
|
|
192
|
+
this.drive.updateQuery(sq.query, sq.label);
|
|
193
|
+
this.sortOptionsAvailable.set(false);
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
else if (q) {
|
|
198
|
+
this.sortOptionsAvailable.set(true);
|
|
199
|
+
try {
|
|
200
|
+
const sq = JSON.parse(decodeURIComponent(q));
|
|
201
|
+
sq.filters = (sq.filters || []).filter((f) => f.f !== BaseObjectTypeField.PARENT_ID);
|
|
202
|
+
this.drive.updateQuery(sq, this.translate.instant('yuv.app.drive.files.search.result.title'));
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
catch (e) {
|
|
206
|
+
console.error('Error parsing query', e);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
this.#eventService
|
|
213
|
+
.on(YuvEventType.DMS_OBJECT_UPDATED)
|
|
214
|
+
.pipe(takeUntilDestroyed(), tap((e) => {
|
|
215
|
+
this.tileList()?.updateTileList([e.data]);
|
|
216
|
+
e.data.id === this.selected()?.id && this.selected.set(e.data);
|
|
217
|
+
}))
|
|
218
|
+
.subscribe();
|
|
219
|
+
}
|
|
220
|
+
onFilterQueryChange(q) {
|
|
221
|
+
this.drive.updateQuery(q, this.translate.instant('yuv.app.drive.files.search.result.title'));
|
|
222
|
+
this.drive.setSelection([]);
|
|
223
|
+
}
|
|
224
|
+
#processLoadError(e) {
|
|
225
|
+
if (`${e.status}` !== this.ERROR_CODE.NOT_FOUND) {
|
|
226
|
+
this.error.set(`${e.status}-${e.error?.serviceErrorCode || ''}`);
|
|
227
|
+
}
|
|
228
|
+
else
|
|
229
|
+
this.error.set(this.ERROR_CODE.NOT_FOUND);
|
|
230
|
+
}
|
|
231
|
+
#getTitle(o) {
|
|
232
|
+
const cfgType = o.isFolder ? this.configTypeOptions['folder'] : this.configTypeOptions['file'];
|
|
233
|
+
const oc = this.#objectConfigService.getResolvedObjectConfig(o.data, cfgType.type, cfgType.bucket, true);
|
|
234
|
+
return oc.title.value;
|
|
235
|
+
}
|
|
236
|
+
onDelete() {
|
|
237
|
+
const deleteAction = this.actions().find((a) => a.id === BASE_ACTION.delete);
|
|
238
|
+
if (deleteAction)
|
|
239
|
+
deleteAction.run(this.drive.state$.selection());
|
|
240
|
+
}
|
|
241
|
+
_setFolderQuery(queryTitle) {
|
|
242
|
+
this.drive.updateQuery({
|
|
243
|
+
filters: [{ f: BaseObjectTypeField.PARENT_ID, o: Operator.EQUAL, v1: this.currentFolderID || null }]
|
|
244
|
+
}, queryTitle);
|
|
245
|
+
}
|
|
246
|
+
onContextmenu({ event }) {
|
|
247
|
+
event.preventDefault();
|
|
248
|
+
this.actionsService.openContextMenu(this.actions, (a) => a.run(this.selection()), { x: event.x, y: event.y });
|
|
249
|
+
}
|
|
250
|
+
onFileDrop(files) {
|
|
251
|
+
this.drive.setBusy(true);
|
|
252
|
+
this.drive.checkNamesAndUpload(files).subscribe({ complete: () => this.drive.setBusy(false) });
|
|
253
|
+
}
|
|
254
|
+
onFileUpdateDrop(file) {
|
|
255
|
+
const dmsObject = this.selected();
|
|
256
|
+
if (dmsObject) {
|
|
257
|
+
this.drive.setBusy(true);
|
|
258
|
+
this.drive
|
|
259
|
+
.uploadContent(dmsObject.id, file[0])
|
|
260
|
+
.pipe(finalize(() => this.drive.setBusy(false)))
|
|
261
|
+
.subscribe();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
itemFocused(tile) {
|
|
265
|
+
// console.log(tile);
|
|
266
|
+
}
|
|
267
|
+
itemClicked(tile) {
|
|
268
|
+
if (this.smallScreenLayout())
|
|
269
|
+
this.itemDoubleClicked(tile);
|
|
270
|
+
}
|
|
271
|
+
onCopy(tiles) {
|
|
272
|
+
this.clipboard.addObjects(tiles.map((t) => t.dmsObject), 'copy', APP_ID);
|
|
273
|
+
}
|
|
274
|
+
onCut(tiles) {
|
|
275
|
+
this.clipboard.addObjects(tiles.map((t) => t.dmsObject), 'cut', APP_ID);
|
|
276
|
+
}
|
|
277
|
+
onQuerySubmit(q) {
|
|
278
|
+
// in order to keep the query in the url as short as
|
|
279
|
+
// possible we'll get rid of the fields because they could be
|
|
280
|
+
// re-applied later on
|
|
281
|
+
q.fields = undefined;
|
|
282
|
+
this.router.navigate(['..', 'query'], {
|
|
283
|
+
queryParams: { q: encodeURIComponent(JSON.stringify(q)) },
|
|
284
|
+
relativeTo: this.route
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
selectionChanged(tiles) {
|
|
288
|
+
if (tiles.length === 1)
|
|
289
|
+
this.loadDetails(tiles[0].id);
|
|
290
|
+
else {
|
|
291
|
+
this.selected.set(undefined);
|
|
292
|
+
if (tiles.length === 0) {
|
|
293
|
+
this.drive.setSelection([]);
|
|
294
|
+
}
|
|
295
|
+
else {
|
|
296
|
+
this.drive.setBusy(true);
|
|
297
|
+
this.dmsService.getDmsObjects(tiles.map((i) => i.id)).subscribe({
|
|
298
|
+
next: (o) => {
|
|
299
|
+
this.drive.setBusy(false);
|
|
300
|
+
this.drive.setSelection(o);
|
|
301
|
+
}
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
itemDoubleClicked(tile) {
|
|
307
|
+
if (tile.instanceData) {
|
|
308
|
+
this.drive.setBusy(true);
|
|
309
|
+
const nav = tile.instanceData[BaseObjectTypeField.BASE_TYPE_ID] === SystemType.FOLDER ? ['..'] : ['../..', 'object'];
|
|
310
|
+
this.router.navigate([...nav, tile.instanceData[BaseObjectTypeField.OBJECT_ID]], { relativeTo: this.route }).then(() => this.drive.setBusy(false));
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
loadDetails(id) {
|
|
314
|
+
this.shellService.addBusy();
|
|
315
|
+
// load the dms object
|
|
316
|
+
this.dmsService.getDmsObject(id).subscribe({
|
|
317
|
+
next: (o) => {
|
|
318
|
+
this.selected.set(o);
|
|
319
|
+
this.shellService.removeBusy();
|
|
320
|
+
this.drive.setSelection([o]);
|
|
321
|
+
}
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
clearSelection() {
|
|
325
|
+
this.drive.setSelection([]);
|
|
326
|
+
}
|
|
327
|
+
openParent() {
|
|
328
|
+
if (this.currentFolder) {
|
|
329
|
+
this.drive.setBusy(true);
|
|
330
|
+
this.router
|
|
331
|
+
.navigate(['..', this.currentFolder.data[BaseObjectTypeField.PARENT_ID] || DRIVE_ROOT_FOLDER_ID], {
|
|
332
|
+
relativeTo: this.route,
|
|
333
|
+
replaceUrl: true
|
|
334
|
+
})
|
|
335
|
+
.then(() => this.drive.setBusy(false));
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
setBusy(busy) {
|
|
339
|
+
this.drive.setBusy(busy);
|
|
340
|
+
}
|
|
341
|
+
refresh() {
|
|
342
|
+
this.tileList()?.refresh();
|
|
343
|
+
this.drive.setSelection([]);
|
|
344
|
+
}
|
|
345
|
+
onLayoutSettingsChange(e) {
|
|
346
|
+
this.#appCache.setItem(this.#LAYOUT_SETTINGS_STORAGE_KEY, e).subscribe();
|
|
347
|
+
}
|
|
348
|
+
#applyLayoutSettings(settings) {
|
|
349
|
+
this.splitViewCmp().applyLayoutSettings(settings);
|
|
350
|
+
}
|
|
351
|
+
ngAfterViewInit() {
|
|
352
|
+
this.#appCache.getItem(this.#LAYOUT_SETTINGS_STORAGE_KEY).subscribe({
|
|
353
|
+
next: (ls) => {
|
|
354
|
+
if (ls) {
|
|
355
|
+
this.enableDetails.set(ls.areas[2]?.visible);
|
|
356
|
+
this.enableTree.set(ls.areas[0]?.visible);
|
|
357
|
+
this.#applyLayoutSettings(ls);
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
ngOnDestroy() {
|
|
363
|
+
this.clipboard.clear(APP_ID);
|
|
364
|
+
}
|
|
365
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilesPageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
366
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FilesPageComponent, isStandalone: true, selector: "ymd-files", inputs: { id: { classPropertyName: "id", publicName: "id", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.smallScreen": "smallScreenLayout()", "class.searchFocused": "this.searchFocused" } }, viewQueries: [{ propertyName: "tileList", first: true, predicate: ["tileList"], descendants: true, isSignal: true }, { propertyName: "splitViewCmp", first: true, predicate: SplitViewComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<header>\n <!-- navigation bar -->\n <nav [attr.aria-label]=\"'yuv.app.drive.files.naviagtion.aria.label' | translate\">\n <div class=\"nav\">\n <button class=\"back\" [disabled]=\"!currentFolder\" title=\"{{ 'yuv.app.drive.files.nav.back.tooltip' | translate }}\" (click)=\"openParent()\">\n <yvc-icon [svg]=\"icons.back\"></yvc-icon>\n </button>\n <button class=\"refresh\" title=\"{{ 'yuv.app.drive.files.nav.refresh.tooltip' | translate }}\" (click)=\"refresh()\">\n <yvc-icon [svg]=\"icons.refresh\"></yvc-icon>\n </button>\n </div>\n\n @if (!query()?.term) {\n <ymd-breadcrumb></ymd-breadcrumb>\n } @else {\n <div class=\"breadcrumb\"></div>\n }\n <div class=\"search\">\n <yuv-simple-search [query]=\"query()\" (querySubmit)=\"onQuerySubmit($event)\"></yuv-simple-search>\n <!-- TODO: enable again once drive search needs to be a little bit more sophisticated -->\n <!-- <ymd-drive-search (focused)=\"searchFocused = $event\"></ymd-drive-search> -->\n </div>\n </nav>\n\n <!-- ribbon with actions and options -->\n <ymd-ribbon [objects]=\"selection()\" [busy]=\"busy()\" [enableClipboard]=\"true\">\n <ng-template #primaryActions>\n <ymd-add-button [disabled]=\"disableCreate\"></ymd-add-button>\n </ng-template>\n\n <ng-template #secondaryActions>\n <div class=\"options\">\n @if (!smallScreenLayout()) {\n <button\n class=\"toggle-tree toggle\"\n [ngClass]=\"{ enabled: enableTree() }\"\n title=\"{{ 'yuv.app.drive.files.toggletree.tooltip' | translate }}\"\n (click)=\"enableTree.set(!enableTree())\"\n >\n <yvc-icon [svg]=\"icons.toggleLeft\"></yvc-icon>\n </button>\n <button\n class=\"toggle-details toggle\"\n [ngClass]=\"{ enabled: enableDetails() }\"\n title=\"{{ 'yuv.app.drive.files.toggledetails.tooltip' | translate }}\"\n (click)=\"enableDetails.set(!enableDetails())\"\n >\n <yvc-icon [svg]=\"icons.toggleRight\"></yvc-icon>\n </button>\n }\n <yuv-tile-config-trigger\n [icon]=\"icons.settings\"\n [bucket]=\"objectConfigBucket\"\n [bucketLabel]=\"tileConfigBucketLabel\"\n [options]=\"tileListOptions\"\n ></yuv-tile-config-trigger>\n </div>\n </ng-template>\n </ymd-ribbon>\n</header>\n\n<yvc-split-view [gutterSize]=\"1\" (layoutSettingsChange)=\"onLayoutSettingsChange($event)\">\n <!-- folder tree -->\n <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableTree() && !smallScreenLayout()\">\n <ymd-folder-tree yuvFocusable=\"Tree\"></ymd-folder-tree>\n </ng-template>\n\n <!-- files -->\n <ng-template yvcSplitArea [size]=\"60\">\n @let err = error();\n @if (err) {\n <div class=\"error\">\n <p>\n <yvc-icon [svg]=\"icons.attention\"></yvc-icon>\n @switch (err) {\n @case (ERROR_CODE.NOT_FOUND) {\n {{ 'yuv.app.drive.files.error.load.not-found' | translate }}\n }\n @case (ERROR_CODE.INVALID_ID) {\n {{ 'yuv.app.drive.files.error.load.invalid-id' | translate }}\n }\n @default {\n {{ 'yuv.app.drive.files.error.load' | translate }}\n }\n }\n </p>\n </div>\n } @else {\n <div class=\"files\" [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.label' | translate }\" (fileDrop)=\"onFileDrop($event)\">\n <header class=\"files-header\">\n <h1>{{ queryTitle() }}</h1>\n @if (query()?.term) {\n <ymd-search-filter [query]=\"query()\" (queryChange)=\"onFilterQueryChange($event)\"></ymd-search-filter>\n }\n @if (sortOptionsAvailable()) {\n <ymd-sort />\n }\n <div class=\"flavors\">\n <!-- TODO: enable again once flavors/aspects are supported -->\n <!-- @for (f of flavorChips; track f.id) {\n <yuv-flavor-chip [ngClass]=\"{ active: f.id === appliedFlavor?.id }\" [flavor]=\"f\" (click)=\"appliedFlavor = f\"></yuv-flavor-chip>\n }-->\n </div>\n </header>\n\n <yuv-tile-list\n #tileList\n class=\"staggered\"\n [attr.aria-label]=\"'yuv.app.drive.files.content.aria.label' | translate\"\n [attr.aria-busy]=\"busy()\"\n [attr.role]=\"'listbox'\"\n (keydown.delete)=\"onDelete()\"\n [bucket]=\"objectConfigBucket\"\n [multiselect]=\"true\"\n [query]=\"query()\"\n [flavor]=\"appliedFlavor\"\n [options]=\"tileListOptions\"\n (itemDblClick)=\"itemDoubleClicked($event)\"\n (itemSelect)=\"itemClicked($event)\"\n (selectionChange)=\"selectionChanged($event)\"\n (copy)=\"onCopy($event)\"\n (cut)=\"onCut($event)\"\n (busy)=\"setBusy($event)\"\n (ctxMenu)=\"onContextmenu($event)\"\n [highlights]=\"highlightStyles$ | async\"\n >\n <div #empty>\n @if (emptyMode() === 'root') {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.root.list' | translate }}</p>\n } @else if (emptyMode() === 'query') {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.query.list' | translate }}</p>\n } @else {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.list' | translate }}</p>\n }\n </div>\n </yuv-tile-list>\n </div>\n }\n </ng-template>\n\n <!-- details -->\n <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableDetails()\">\n @let selectedItem = selected();\n @if (enableDetails() && selectedItem) {\n @if (selectedItem?.isFolder) {\n <yuv-object-summary [configType]=\"configTypeOptions['folder']\" [dmsObject]=\"selectedItem\"></yuv-object-summary>\n } @else {\n <yuv-object-summary\n [configType]=\"configTypeOptions['file']\"\n [dmsObject]=\"selectedItem\"\n [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.content.replace.label' | translate }\"\n [fileDropDisabled]=\"fileDropSummaryDisabled()\"\n (fileDrop)=\"onFileUpdateDrop($event)\"\n ></yuv-object-summary>\n }\n } @else {\n @let sel = selection();\n @if (sel && sel.length > 0) {\n <yuv-multi-object-summary [headline]=\"'yuv.app.drive.multiselected.details' | translate: { count: selection().length }\"></yuv-multi-object-summary>\n } @else if (tileList()?.items?.length === 0) {\n <!-- TODO: CHOULD HAVE A DIFFERENT MESSAGE FOR EMPTY RESULTS EMPTY FOR NOW -->\n <div class=\"message\">{{ 'yuv.app.drive.empty.results.details.message' | translate }}</div>\n } @else {\n <div class=\"message\">{{ 'yuv.app.drive.unselected.details' | translate }}</div>\n }\n }\n </ng-template>\n</yvc-split-view>\n", styles: [":host{--files-button-padding: calc(var(--app-pane-padding) / 4);--files-button-border-radius: 2px;--files-button-gap: calc(var(--app-pane-padding) / 4);--files-icon-size: 20px;height:100%;overflow:hidden;display:flex;flex-flow:column}:host.searchFocused header>nav .search{grid-column:-1/-3}:host header{flex:0 0 auto}:host header>nav{background-color:var(--app-drive-header-background);border-block-end:1px solid var(--panel-divider-color);display:grid;grid-template-columns:auto 1fr 1fr auto;align-items:center;gap:calc(var(--app-pane-padding) / 2);padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2)}:host header>nav .nav{grid-column:1/2;grid-row:1;display:flex;align-items:center;gap:var(--files-button-gap)}:host header>nav .nav button{padding:var(--files-button-padding);border-radius:var(--files-button-border-radius)}:host header>nav .nav button yvc-icon{--icon-size: var(--files-icon-size)}:host header>nav .breadcrumb{grid-column:2/4;grid-row:1;align-self:stretch;display:flex;align-items:center;border-radius:var(--files-button-border-radius);padding:0 .5em;border:1px solid var(--panel-divider-color)}:host header>nav .search{grid-column:-1/-2;grid-row:1;z-index:1}:host yvc-split-view{flex:1;animation:fade-in .3s ease-in-out}:host ymd-ribbon{--ribbon-button-padding: var(--files-button-padding);--ribbon-button-border-radius: var(--files-button-border-radius);--ribbon-button-gap: var(--files-button-gap);--ribbon-icon-size: var(--files-icon-size)}:host ymd-ribbon .options{grid-area:options;display:flex;gap:var(--files-button-gap);align-items:center}:host ymd-ribbon .options yuv-tile-config-trigger{--icon-size: var(--files-icon-size);--button-padding: var(--files-button-padding)}:host ymd-ribbon .options button{padding:var(--files-button-padding);border-radius:var(--files-button-border-radius)}:host ymd-ribbon .options button yvc-icon{--icon-size: var(--files-icon-size)}:host ymd-ribbon .options button.toggle.enabled{background-color:var(--item-focus-background-color)}:host main{height:100%;overflow:hidden;display:flex;flex-flow:column}:host main yvc-master-details{flex:1;overflow:hidden;box-sizing:border-box}:host .error{display:grid;justify-items:center;align-items:center;height:100%;padding:0 2rem;text-align:center;color:var(--text-color-caption)}:host .error p{max-width:31ch;line-height:1.5em;display:grid;justify-items:center}:host .error p yvc-icon{--icon-size: 48px;display:block;margin-block-end:1rem}:host .files{display:flex;flex-flow:column;overflow:hidden;height:100%}:host .files header{flex:0 0 auto;padding:var(--app-pane-padding);display:grid;grid-template-columns:2fr max-content;grid-template-rows:auto auto 1fr;gap:0;grid-auto-flow:row;grid-template-areas:\"title sort\" \"searchfilter searchfilter\" \"flavours flavours\"}:host .files header h1{grid-area:title;margin:0;padding:0;font-size:var(--font-title);font-weight:400;text-overflow:ellipsis;overflow:hidden}:host .files header .flavors{grid-area:flavors;display:flex;gap:2px;justify-content:flex-end;padding:calc(var(--app-pane-padding) / 4)}:host .files header .flavors yuv-flavor-chip{font-size:var(--font-hint);cursor:pointer;--flavor-background: var(--panel-background);--flavor-icon-size: 16px}:host .files header .flavors yuv-flavor-chip:hover{--flavor-border-color: var(--color-accent)}:host .files header ymd-sort{grid-area:sort}:host .files header ymd-search-filter{grid-area:searchfilter}:host .files yuv-tile-list{flex:1;overflow:hidden}:host .message{display:grid;justify-items:center;align-items:center;height:100%;padding:0 2rem;text-align:center;color:var(--text-color-caption)}:host .message p{max-width:31ch;line-height:1.5em}:host yvc-split-view{height:100%;box-sizing:border-box}:host ymd-folder-tree,:host yuv-object-summary{height:100%;overflow-y:auto;box-sizing:border-box}:host yuv-tile-list{--tile-border: 1px solid var(--panel-divider-color);--tile-border-width: 0 0 1px 0;--tile-padding: calc(var(--app-pane-padding) / 2);--tile-icon-size: 18px;--tile-action-icon-size: 18px;--paging-background: var(--panel-background-lightgrey)}:host p.empty{color:var(--text-color-caption)}:host .details{height:100%}:host .details yuv-object-details{height:100%}:host.smallScreen yuv-tile-list{--tile-padding: var(--app-pane-padding) !important}@keyframes fade-in{0%{opacity:0}}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: YvcIconModule }, { kind: "component", type: i1.Icon, selector: "yvc-icon", inputs: ["label", "svg", "svgSrc"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: RouterModule }, { kind: "ngmodule", type: YvcSplitViewModule }, { kind: "component", type: i3.SplitViewComponent, selector: "yvc-split-view", inputs: ["direction", "gutterSize", "restrictMove", "disabled", "gutterDblClickDuration", "layoutSettingsID"], outputs: ["layoutSettingsChange", "dragStart", "dragEnd", "gutterClick", "gutterDblClick"] }, { kind: "directive", type: i3.SplitAreaDirective, selector: "[yvcSplitArea]", inputs: ["size", "order", "minSize", "maxSize", "panelClass", "visible"] }, { kind: "component", type: TileListComponent, selector: "yuv-tile-list", inputs: ["bucket", "multiselect", "options", "flavor", "query", "preselect", "highlights"], outputs: ["itemSelect", "copy", "cut", "busy", "queryResult", "selectionChange", "itemDblClick", "ctxMenu"] }, { kind: "component", type: BreadcrumbComponent, selector: "ymd-breadcrumb" }, { kind: "component", type: FolderTreeComponent, selector: "ymd-folder-tree" }, { kind: "component", type: ObjectSummaryComponent, selector: "yuv-object-summary", inputs: ["actions", "dmsObject", "objectId", "configType"] }, { kind: "component", type: TileConfigTriggerComponent, selector: "yuv-tile-config-trigger", inputs: ["icon", "bucket", "bucketLabel", "options"] }, { kind: "component", type: RibbonComponent, selector: "ymd-ribbon", inputs: ["busy", "enableClipboard", "objects", "excludeActions"] }, { kind: "component", type: AddButtonComponent, selector: "ymd-add-button", inputs: ["disabled"] }, { kind: "component", type: SimpleSearchComponent, selector: "yuv-simple-search", inputs: ["targets", "query"], outputs: ["querySubmit", "targetSelectionChanged", "queryChange", "typeAggregation"] }, { kind: "component", type: MultiObjectSummaryComponent, selector: "yuv-multi-object-summary", inputs: ["headline"] }, { kind: "component", type: SortComponent, selector: "ymd-sort", outputs: ["sortChanged"] }, { kind: "component", type: SearchFilterComponent, selector: "ymd-search-filter", inputs: ["query"], outputs: ["queryChange"] }, { kind: "directive", type: FileDropZoneDirective, selector: "[yuvFileDropZone]", inputs: ["yuvFileDropZone", "fileDropDisabled"], outputs: ["fileDrop", "fileDropOver"] }] }); }
|
|
367
|
+
}
|
|
368
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilesPageComponent, decorators: [{
|
|
369
|
+
type: Component,
|
|
370
|
+
args: [{ selector: 'ymd-files', standalone: true, imports: [NgClass, AsyncPipe, ...module, ...components, FileDropZoneDirective], host: {
|
|
371
|
+
'[class.smallScreen]': 'smallScreenLayout()'
|
|
372
|
+
}, template: "<header>\n <!-- navigation bar -->\n <nav [attr.aria-label]=\"'yuv.app.drive.files.naviagtion.aria.label' | translate\">\n <div class=\"nav\">\n <button class=\"back\" [disabled]=\"!currentFolder\" title=\"{{ 'yuv.app.drive.files.nav.back.tooltip' | translate }}\" (click)=\"openParent()\">\n <yvc-icon [svg]=\"icons.back\"></yvc-icon>\n </button>\n <button class=\"refresh\" title=\"{{ 'yuv.app.drive.files.nav.refresh.tooltip' | translate }}\" (click)=\"refresh()\">\n <yvc-icon [svg]=\"icons.refresh\"></yvc-icon>\n </button>\n </div>\n\n @if (!query()?.term) {\n <ymd-breadcrumb></ymd-breadcrumb>\n } @else {\n <div class=\"breadcrumb\"></div>\n }\n <div class=\"search\">\n <yuv-simple-search [query]=\"query()\" (querySubmit)=\"onQuerySubmit($event)\"></yuv-simple-search>\n <!-- TODO: enable again once drive search needs to be a little bit more sophisticated -->\n <!-- <ymd-drive-search (focused)=\"searchFocused = $event\"></ymd-drive-search> -->\n </div>\n </nav>\n\n <!-- ribbon with actions and options -->\n <ymd-ribbon [objects]=\"selection()\" [busy]=\"busy()\" [enableClipboard]=\"true\">\n <ng-template #primaryActions>\n <ymd-add-button [disabled]=\"disableCreate\"></ymd-add-button>\n </ng-template>\n\n <ng-template #secondaryActions>\n <div class=\"options\">\n @if (!smallScreenLayout()) {\n <button\n class=\"toggle-tree toggle\"\n [ngClass]=\"{ enabled: enableTree() }\"\n title=\"{{ 'yuv.app.drive.files.toggletree.tooltip' | translate }}\"\n (click)=\"enableTree.set(!enableTree())\"\n >\n <yvc-icon [svg]=\"icons.toggleLeft\"></yvc-icon>\n </button>\n <button\n class=\"toggle-details toggle\"\n [ngClass]=\"{ enabled: enableDetails() }\"\n title=\"{{ 'yuv.app.drive.files.toggledetails.tooltip' | translate }}\"\n (click)=\"enableDetails.set(!enableDetails())\"\n >\n <yvc-icon [svg]=\"icons.toggleRight\"></yvc-icon>\n </button>\n }\n <yuv-tile-config-trigger\n [icon]=\"icons.settings\"\n [bucket]=\"objectConfigBucket\"\n [bucketLabel]=\"tileConfigBucketLabel\"\n [options]=\"tileListOptions\"\n ></yuv-tile-config-trigger>\n </div>\n </ng-template>\n </ymd-ribbon>\n</header>\n\n<yvc-split-view [gutterSize]=\"1\" (layoutSettingsChange)=\"onLayoutSettingsChange($event)\">\n <!-- folder tree -->\n <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableTree() && !smallScreenLayout()\">\n <ymd-folder-tree yuvFocusable=\"Tree\"></ymd-folder-tree>\n </ng-template>\n\n <!-- files -->\n <ng-template yvcSplitArea [size]=\"60\">\n @let err = error();\n @if (err) {\n <div class=\"error\">\n <p>\n <yvc-icon [svg]=\"icons.attention\"></yvc-icon>\n @switch (err) {\n @case (ERROR_CODE.NOT_FOUND) {\n {{ 'yuv.app.drive.files.error.load.not-found' | translate }}\n }\n @case (ERROR_CODE.INVALID_ID) {\n {{ 'yuv.app.drive.files.error.load.invalid-id' | translate }}\n }\n @default {\n {{ 'yuv.app.drive.files.error.load' | translate }}\n }\n }\n </p>\n </div>\n } @else {\n <div class=\"files\" [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.label' | translate }\" (fileDrop)=\"onFileDrop($event)\">\n <header class=\"files-header\">\n <h1>{{ queryTitle() }}</h1>\n @if (query()?.term) {\n <ymd-search-filter [query]=\"query()\" (queryChange)=\"onFilterQueryChange($event)\"></ymd-search-filter>\n }\n @if (sortOptionsAvailable()) {\n <ymd-sort />\n }\n <div class=\"flavors\">\n <!-- TODO: enable again once flavors/aspects are supported -->\n <!-- @for (f of flavorChips; track f.id) {\n <yuv-flavor-chip [ngClass]=\"{ active: f.id === appliedFlavor?.id }\" [flavor]=\"f\" (click)=\"appliedFlavor = f\"></yuv-flavor-chip>\n }-->\n </div>\n </header>\n\n <yuv-tile-list\n #tileList\n class=\"staggered\"\n [attr.aria-label]=\"'yuv.app.drive.files.content.aria.label' | translate\"\n [attr.aria-busy]=\"busy()\"\n [attr.role]=\"'listbox'\"\n (keydown.delete)=\"onDelete()\"\n [bucket]=\"objectConfigBucket\"\n [multiselect]=\"true\"\n [query]=\"query()\"\n [flavor]=\"appliedFlavor\"\n [options]=\"tileListOptions\"\n (itemDblClick)=\"itemDoubleClicked($event)\"\n (itemSelect)=\"itemClicked($event)\"\n (selectionChange)=\"selectionChanged($event)\"\n (copy)=\"onCopy($event)\"\n (cut)=\"onCut($event)\"\n (busy)=\"setBusy($event)\"\n (ctxMenu)=\"onContextmenu($event)\"\n [highlights]=\"highlightStyles$ | async\"\n >\n <div #empty>\n @if (emptyMode() === 'root') {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.root.list' | translate }}</p>\n } @else if (emptyMode() === 'query') {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.query.list' | translate }}</p>\n } @else {\n <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.list' | translate }}</p>\n }\n </div>\n </yuv-tile-list>\n </div>\n }\n </ng-template>\n\n <!-- details -->\n <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableDetails()\">\n @let selectedItem = selected();\n @if (enableDetails() && selectedItem) {\n @if (selectedItem?.isFolder) {\n <yuv-object-summary [configType]=\"configTypeOptions['folder']\" [dmsObject]=\"selectedItem\"></yuv-object-summary>\n } @else {\n <yuv-object-summary\n [configType]=\"configTypeOptions['file']\"\n [dmsObject]=\"selectedItem\"\n [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.content.replace.label' | translate }\"\n [fileDropDisabled]=\"fileDropSummaryDisabled()\"\n (fileDrop)=\"onFileUpdateDrop($event)\"\n ></yuv-object-summary>\n }\n } @else {\n @let sel = selection();\n @if (sel && sel.length > 0) {\n <yuv-multi-object-summary [headline]=\"'yuv.app.drive.multiselected.details' | translate: { count: selection().length }\"></yuv-multi-object-summary>\n } @else if (tileList()?.items?.length === 0) {\n <!-- TODO: CHOULD HAVE A DIFFERENT MESSAGE FOR EMPTY RESULTS EMPTY FOR NOW -->\n <div class=\"message\">{{ 'yuv.app.drive.empty.results.details.message' | translate }}</div>\n } @else {\n <div class=\"message\">{{ 'yuv.app.drive.unselected.details' | translate }}</div>\n }\n }\n </ng-template>\n</yvc-split-view>\n", styles: [":host{--files-button-padding: calc(var(--app-pane-padding) / 4);--files-button-border-radius: 2px;--files-button-gap: calc(var(--app-pane-padding) / 4);--files-icon-size: 20px;height:100%;overflow:hidden;display:flex;flex-flow:column}:host.searchFocused header>nav .search{grid-column:-1/-3}:host header{flex:0 0 auto}:host header>nav{background-color:var(--app-drive-header-background);border-block-end:1px solid var(--panel-divider-color);display:grid;grid-template-columns:auto 1fr 1fr auto;align-items:center;gap:calc(var(--app-pane-padding) / 2);padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2)}:host header>nav .nav{grid-column:1/2;grid-row:1;display:flex;align-items:center;gap:var(--files-button-gap)}:host header>nav .nav button{padding:var(--files-button-padding);border-radius:var(--files-button-border-radius)}:host header>nav .nav button yvc-icon{--icon-size: var(--files-icon-size)}:host header>nav .breadcrumb{grid-column:2/4;grid-row:1;align-self:stretch;display:flex;align-items:center;border-radius:var(--files-button-border-radius);padding:0 .5em;border:1px solid var(--panel-divider-color)}:host header>nav .search{grid-column:-1/-2;grid-row:1;z-index:1}:host yvc-split-view{flex:1;animation:fade-in .3s ease-in-out}:host ymd-ribbon{--ribbon-button-padding: var(--files-button-padding);--ribbon-button-border-radius: var(--files-button-border-radius);--ribbon-button-gap: var(--files-button-gap);--ribbon-icon-size: var(--files-icon-size)}:host ymd-ribbon .options{grid-area:options;display:flex;gap:var(--files-button-gap);align-items:center}:host ymd-ribbon .options yuv-tile-config-trigger{--icon-size: var(--files-icon-size);--button-padding: var(--files-button-padding)}:host ymd-ribbon .options button{padding:var(--files-button-padding);border-radius:var(--files-button-border-radius)}:host ymd-ribbon .options button yvc-icon{--icon-size: var(--files-icon-size)}:host ymd-ribbon .options button.toggle.enabled{background-color:var(--item-focus-background-color)}:host main{height:100%;overflow:hidden;display:flex;flex-flow:column}:host main yvc-master-details{flex:1;overflow:hidden;box-sizing:border-box}:host .error{display:grid;justify-items:center;align-items:center;height:100%;padding:0 2rem;text-align:center;color:var(--text-color-caption)}:host .error p{max-width:31ch;line-height:1.5em;display:grid;justify-items:center}:host .error p yvc-icon{--icon-size: 48px;display:block;margin-block-end:1rem}:host .files{display:flex;flex-flow:column;overflow:hidden;height:100%}:host .files header{flex:0 0 auto;padding:var(--app-pane-padding);display:grid;grid-template-columns:2fr max-content;grid-template-rows:auto auto 1fr;gap:0;grid-auto-flow:row;grid-template-areas:\"title sort\" \"searchfilter searchfilter\" \"flavours flavours\"}:host .files header h1{grid-area:title;margin:0;padding:0;font-size:var(--font-title);font-weight:400;text-overflow:ellipsis;overflow:hidden}:host .files header .flavors{grid-area:flavors;display:flex;gap:2px;justify-content:flex-end;padding:calc(var(--app-pane-padding) / 4)}:host .files header .flavors yuv-flavor-chip{font-size:var(--font-hint);cursor:pointer;--flavor-background: var(--panel-background);--flavor-icon-size: 16px}:host .files header .flavors yuv-flavor-chip:hover{--flavor-border-color: var(--color-accent)}:host .files header ymd-sort{grid-area:sort}:host .files header ymd-search-filter{grid-area:searchfilter}:host .files yuv-tile-list{flex:1;overflow:hidden}:host .message{display:grid;justify-items:center;align-items:center;height:100%;padding:0 2rem;text-align:center;color:var(--text-color-caption)}:host .message p{max-width:31ch;line-height:1.5em}:host yvc-split-view{height:100%;box-sizing:border-box}:host ymd-folder-tree,:host yuv-object-summary{height:100%;overflow-y:auto;box-sizing:border-box}:host yuv-tile-list{--tile-border: 1px solid var(--panel-divider-color);--tile-border-width: 0 0 1px 0;--tile-padding: calc(var(--app-pane-padding) / 2);--tile-icon-size: 18px;--tile-action-icon-size: 18px;--paging-background: var(--panel-background-lightgrey)}:host p.empty{color:var(--text-color-caption)}:host .details{height:100%}:host .details yuv-object-details{height:100%}:host.smallScreen yuv-tile-list{--tile-padding: var(--app-pane-padding) !important}@keyframes fade-in{0%{opacity:0}}\n"] }]
|
|
373
|
+
}], ctorParameters: () => [], propDecorators: { searchFocused: [{
|
|
374
|
+
type: HostBinding,
|
|
375
|
+
args: ['class.searchFocused']
|
|
376
|
+
}] } });
|
|
377
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files.component.js","sourceRoot":"","sources":["../../../../../../../../libs/apps/drive/src/lib/pages/files/files.component.ts","../../../../../../../../libs/apps/drive/src/lib/pages/files/files.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass } from '@angular/common';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, Component, computed, effect, HostBinding, inject, input, OnDestroy, Signal, signal, untracked, viewChild } from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { ActivatedRoute, ParamMap, Router, RouterModule } from '@angular/router';\nimport {\n  AppCacheService,\n  BaseObjectTypeField,\n  ClipboardService,\n  ConfigTypeOption,\n  DeviceScreen,\n  DeviceService,\n  DmsObject,\n  DmsService,\n  EventService,\n  ObjectConfigService,\n  Operator,\n  ResolvedObjectConfig,\n  SearchQuery,\n  SystemType,\n  TranslateModule,\n  TranslateService,\n  YuvEventType\n} from '@yuuvis/client-core';\nimport { Action, ActionsService, BASE_ACTION } from '@yuuvis/client-framework/actions';\nimport { FileDropZoneDirective } from '@yuuvis/client-framework/common';\nimport { YUV_ICONS } from '@yuuvis/client-framework/icons';\nimport { MultiObjectSummaryComponent, ObjectSummaryComponent } from '@yuuvis/client-framework/object-summary';\nimport { SimpleSearchComponent } from '@yuuvis/client-framework/simple-search';\nimport { TileConfigTriggerComponent, TileData, TileListComponent, TileListConfigOptions, TileListHighlight } from '@yuuvis/client-framework/tile-list';\nimport { ObjectFlavor, ShellService } from '@yuuvis/client-shell-core';\nimport { ICONS, YvcIconModule } from '@yuuvis/components/icon';\nimport { MenuItem } from '@yuuvis/components/overflow-menu';\nimport { SplitViewComponent, SplitViewLayoutSettings, YvcSplitViewModule } from '@yuuvis/components/split-view';\nimport { finalize, map, Observable, switchMap, tap } from 'rxjs';\nimport { BreadcrumbComponent, SortComponent } from '../../components';\nimport { AddButtonComponent } from '../../components/add-button/add-button.component';\nimport { FolderTreeComponent } from '../../components/folder-tree/folder-tree.component';\nimport { RibbonComponent } from '../../components/ribbon/ribbon.component';\nimport { APP_DRIVE_ICONS } from '../../drive.icons';\nimport { ACTION_CONTEXT, APP_ID, APP_SCHEMA } from '../../drive.schema';\nimport { DRIVE_EVENT, DRIVE_QUERY_FOLDER_ID, DRIVE_ROOT_FOLDER_ID, DriveFolderId } from '../../services/drive/drive.interface';\nimport { DriveService } from '../../services/drive/drive.service';\nimport { STORED_QUERY_ID_PREFIX } from '../../services/stored-query/stored-query.data';\nimport { StoredQuery } from '../../services/stored-query/stored-query.interface';\nimport { StoredQueryService } from '../../services/stored-query/stored-query.service';\nimport { SearchFilterComponent } from '../../components/search-filter/search-filter.component';\n\nconst components = [\n  TileListComponent,\n  BreadcrumbComponent,\n  FolderTreeComponent,\n  ObjectSummaryComponent,\n  TileConfigTriggerComponent,\n  RibbonComponent,\n  AddButtonComponent,\n  SimpleSearchComponent,\n  MultiObjectSummaryComponent,\n  SortComponent,\n  SearchFilterComponent\n];\n\nconst module = [YvcIconModule, TranslateModule, RouterModule, YvcSplitViewModule];\n\n@Component({\n  selector: 'ymd-files',\n  standalone: true,\n  imports: [NgClass, AsyncPipe, ...module, ...components, FileDropZoneDirective],\n  templateUrl: './files.component.html',\n  styleUrl: './files.component.scss',\n  host: {\n    '[class.smallScreen]': 'smallScreenLayout()'\n  }\n})\nexport class FilesPageComponent implements AfterViewInit, OnDestroy {\n  tileList = viewChild<TileListComponent>('tileList');\n\n  #LAYOUT_SETTINGS_STORAGE_KEY = 'yuv.app.drive.files.layout';\n\n  private shellService = inject(ShellService);\n  private dmsService = inject(DmsService);\n  private drive = inject(DriveService);\n  private route = inject(ActivatedRoute);\n  private router = inject(Router);\n  private translate = inject(TranslateService);\n  private storedQueryService = inject(StoredQueryService);\n  private clipboard = inject(ClipboardService);\n  private actionsService = inject(ActionsService);\n  readonly #objectConfigService = inject(ObjectConfigService);\n  readonly #device = inject(DeviceService);\n\n  readonly #eventService = inject(EventService);\n\n  readonly ERROR_CODE = {\n    NOT_FOUND: '404',\n    // pattern: {HTTP_STATUS_CODE}-{SERVICE_ERROR_CODE}\n    INVALID_ID: '422-2912'\n  };\n\n  #appCache = inject(AppCacheService);\n\n  objectConfigBucket: string = APP_SCHEMA.id;\n\n  splitViewCmp = viewChild.required(SplitViewComponent);\n  selected = signal<DmsObject | undefined>(undefined);\n  fileDropSummaryDisabled = computed(() => !this.selected()?.permissions?.writeContent);\n  disableCreate = false;\n\n  actions = this.drive.state$.actions;\n  selection = this.drive.state$.selection;\n\n  busy = this.drive.state$.busy;\n  flavorChips: ObjectFlavor[] = this.shellService.getObjectFlavors();\n  appliedFlavor?: ObjectFlavor;\n\n  selectionActions = computed(() => ({ selection: this.selection(), actions: this.actions() }));\n\n  emptyMode = signal<DriveFolderId | null>(null);\n  // error code when loading the object failed. This will be used\n  // to determine a proper error message to display\n  error = signal<string | undefined>(undefined);\n\n  configTypeOptions: Record<string, ConfigTypeOption> = {\n    folder: { bucket: APP_ID, type: APP_SCHEMA.types['folder'] },\n    file: { bucket: APP_ID, type: APP_SCHEMA.types['file'] }\n  };\n\n  @HostBinding('class.searchFocused') searchFocused = false;\n\n  currentFolderID?: string;\n  currentFolder?: DmsObject;\n  enableDetails = signal<boolean>(true);\n  enableTree = signal<boolean>(true);\n  tileConfigBucketLabel = this.translate.instant('yuv.app.drive.tile-config.bucket');\n\n  smallScreenLayout = signal(false);\n  sortOptionsAvailable = signal(true);\n\n  id = input<string | null>(null);\n\n  highlightStyles$: Observable<TileListHighlight[]> = this.clipboard.clipboard$(APP_ID).pipe(\n    takeUntilDestroyed(),\n    map((c) => {\n      return c && c.mode && c.objects?.length\n        ? [\n            {\n              cssStyles: this.#highlightStyles[c?.mode],\n              ids: c.objects.map((o) => o.id)\n            }\n          ]\n        : [];\n    })\n  );\n\n  readonly #highlightStyles: Record<string, Record<string, unknown>> = {\n    cut: { opacity: 0.5 }\n  };\n\n  #routeIdEffect = effect(() => {\n    const param = this.id() || undefined;\n\n    untracked(async () => {\n      if (param === DRIVE_QUERY_FOLDER_ID) {\n        this.emptyMode.set(DRIVE_QUERY_FOLDER_ID);\n        return;\n      }\n\n      this.emptyMode.set(param === DRIVE_ROOT_FOLDER_ID ? DRIVE_ROOT_FOLDER_ID : null);\n      this.error.set(undefined);\n      this.disableCreate = false;\n      this.currentFolderID = param;\n      this.drive.updateCurrentFolder(this.currentFolderID);\n      this.selected.set(undefined);\n      this.currentFolder = undefined;\n      if (this.currentFolderID === DRIVE_ROOT_FOLDER_ID) this.currentFolderID = undefined;\n\n      if (this.currentFolderID) {\n        this.dmsService.getDmsObject(this.currentFolderID).subscribe({\n          next: (o: DmsObject) => {\n            this.currentFolder = o;\n            this._setFolderQuery(this.#getTitle(o));\n          },\n          error: (e) => {\n            console.error('Error getting folder', e);\n            this.#processLoadError(e);\n          }\n        });\n      } else this._setFolderQuery(this.translate.instant('yuv.app.drive.folder-tree.mydrive'));\n    });\n  });\n\n  tileListOptions: TileListConfigOptions = {\n    actionContext: ACTION_CONTEXT,\n    configTypes: Object.values(APP_SCHEMA.types),\n    configFlavors: [...this.shellService.getObjectFlavors(), ...APP_SCHEMA.flavors.filter((f) => !f.applicableTo).map((f) => ({ ...f, app: APP_ID }))]\n  };\n\n  query = this.drive.state$.query;\n  queryTitle = this.drive.state$.queryTitle;\n\n  icons = {\n    ...APP_DRIVE_ICONS,\n    sort: APP_DRIVE_ICONS.sort,\n    back: YUV_ICONS.back,\n    attention: YUV_ICONS.attention,\n    refresh: YUV_ICONS.refresh,\n    clear: ICONS.clear\n  };\n\n  constructor() {\n    this.drive.events$.pipe(takeUntilDestroyed()).subscribe({\n      next: (e) => {\n        if (e === DRIVE_EVENT.refresh) {\n          this.refresh();\n        }\n      }\n    });\n\n    this.#device.screenChange$.pipe(takeUntilDestroyed()).subscribe({\n      next: (s: DeviceScreen) => {\n        this.smallScreenLayout.set(s.size === 's' && s.orientation === 'portrait');\n        this.enableDetails.set(!this.smallScreenLayout());\n      }\n    });\n\n    toObservable(this.drive.state$.selection)\n      .pipe(takeUntilDestroyed())\n      .subscribe({\n        next: (sel: DmsObject[]) => {\n          if (sel?.length === 0) {\n            this.tileList()?.clearSelection(true);\n            this.selected.set(undefined);\n          }\n        }\n      });\n\n    this.route.queryParamMap.pipe(takeUntilDestroyed()).subscribe({\n      next: (p: ParamMap) => {\n        this.sortOptionsAvailable.set(true);\n        if (this.route.snapshot.params['id'] === DRIVE_QUERY_FOLDER_ID) {\n          const q = p.get('q');\n          this.disableCreate = true;\n          // check if the query is a stored query\n          if (q?.startsWith(STORED_QUERY_ID_PREFIX)) {\n            const sq: StoredQuery | undefined = this.storedQueryService.getStoredQuery(q);\n            if (sq) {\n              this.drive.updateQuery(sq.query, sq.label);\n              this.sortOptionsAvailable.set(false);\n              return;\n            }\n          } else if (q) {\n            this.sortOptionsAvailable.set(true);\n            try {\n              const sq: SearchQuery = JSON.parse(decodeURIComponent(q));\n              sq.filters = (sq.filters || []).filter((f) => f.f !== BaseObjectTypeField.PARENT_ID);\n              this.drive.updateQuery(sq, this.translate.instant('yuv.app.drive.files.search.result.title'));\n              return;\n            } catch (e) {\n              console.error('Error parsing query', e);\n            }\n          }\n        }\n      }\n    });\n\n    this.#eventService\n      .on(YuvEventType.DMS_OBJECT_UPDATED)\n      .pipe(\n        takeUntilDestroyed(),\n        tap((e) => {\n          this.tileList()?.updateTileList([e.data]);\n          e.data.id === this.selected()?.id && this.selected.set(e.data);\n        })\n      )\n      .subscribe();\n  }\n\n  onFilterQueryChange(q: SearchQuery) {\n    this.drive.updateQuery(q, this.translate.instant('yuv.app.drive.files.search.result.title'));\n    this.drive.setSelection([]);\n  }\n\n  #processLoadError(e: HttpErrorResponse) {\n    if (`${e.status}` !== this.ERROR_CODE.NOT_FOUND) {\n      this.error.set(`${e.status}-${e.error?.serviceErrorCode || ''}`);\n    } else this.error.set(this.ERROR_CODE.NOT_FOUND);\n  }\n\n  #getTitle(o: DmsObject): string {\n    const cfgType: ConfigTypeOption = o.isFolder ? this.configTypeOptions['folder'] : this.configTypeOptions['file'];\n    const oc: ResolvedObjectConfig = this.#objectConfigService.getResolvedObjectConfig(o.data, cfgType.type, cfgType.bucket, true);\n    return oc.title.value;\n  }\n\n  onDelete() {\n    const deleteAction = this.actions().find((a) => a.id === BASE_ACTION.delete);\n    if (deleteAction) deleteAction.run(this.drive.state$.selection());\n  }\n\n  private _setFolderQuery(queryTitle?: string) {\n    this.drive.updateQuery(\n      {\n        filters: [{ f: BaseObjectTypeField.PARENT_ID, o: Operator.EQUAL, v1: this.currentFolderID || null }]\n      },\n      queryTitle\n    );\n  }\n\n  onContextmenu({ event }: { event: MouseEvent | PointerEvent }) {\n    event.preventDefault();\n    this.actionsService.openContextMenu(this.actions, (a: Action) => a.run(this.selection()), { x: event.x, y: event.y });\n  }\n\n  onFileDrop(files: File[]) {\n    this.drive.setBusy(true);\n    this.drive.checkNamesAndUpload(files).subscribe({ complete: () => this.drive.setBusy(false) });\n  }\n\n  onFileUpdateDrop(file: File[]) {\n    const dmsObject = this.selected();\n    if (dmsObject) {\n      this.drive.setBusy(true);\n      this.drive\n        .uploadContent(dmsObject.id, file[0])\n        .pipe(finalize(() => this.drive.setBusy(false)))\n        .subscribe();\n    }\n  }\n\n  itemFocused(tile: TileData) {\n    // console.log(tile);\n  }\n\n  itemClicked(tile: TileData) {\n    if (this.smallScreenLayout()) this.itemDoubleClicked(tile);\n  }\n\n  onCopy(tiles: TileData[]) {\n    this.clipboard.addObjects(\n      tiles.map((t) => t.dmsObject),\n      'copy',\n      APP_ID\n    );\n  }\n\n  onCut(tiles: TileData[]) {\n    this.clipboard.addObjects(\n      tiles.map((t) => t.dmsObject),\n      'cut',\n      APP_ID\n    );\n  }\n\n  onQuerySubmit(q: SearchQuery) {\n    // in order to keep the query in the url as short as\n    // possible we'll get rid of the fields because they could be\n    // re-applied later on\n    q.fields = undefined;\n\n    this.router.navigate(['..', 'query'], {\n      queryParams: { q: encodeURIComponent(JSON.stringify(q)) },\n      relativeTo: this.route\n    });\n  }\n\n  selectionChanged(tiles: TileData[]) {\n    if (tiles.length === 1) this.loadDetails(tiles[0].id);\n    else {\n      this.selected.set(undefined);\n      if (tiles.length === 0) {\n        this.drive.setSelection([]);\n      } else {\n        this.drive.setBusy(true);\n        this.dmsService.getDmsObjects(tiles.map((i) => i.id)).subscribe({\n          next: (o: DmsObject[]) => {\n            this.drive.setBusy(false);\n            this.drive.setSelection(o);\n          }\n        });\n      }\n    }\n  }\n\n  itemDoubleClicked(tile: TileData) {\n    if (tile.instanceData) {\n      this.drive.setBusy(true);\n      const nav = (tile.instanceData[BaseObjectTypeField.BASE_TYPE_ID] as string) === SystemType.FOLDER ? ['..'] : ['../..', 'object'];\n      this.router.navigate([...nav, tile.instanceData[BaseObjectTypeField.OBJECT_ID]], { relativeTo: this.route }).then(() => this.drive.setBusy(false));\n    }\n  }\n\n  loadDetails(id: string) {\n    this.shellService.addBusy();\n    // load the dms object\n    this.dmsService.getDmsObject(id).subscribe({\n      next: (o: DmsObject) => {\n        this.selected.set(o);\n        this.shellService.removeBusy();\n        this.drive.setSelection([o]);\n      }\n    });\n  }\n\n  clearSelection() {\n    this.drive.setSelection([]);\n  }\n\n  openParent() {\n    if (this.currentFolder) {\n      this.drive.setBusy(true);\n      this.router\n        .navigate(['..', this.currentFolder.data[BaseObjectTypeField.PARENT_ID] || DRIVE_ROOT_FOLDER_ID], {\n          relativeTo: this.route,\n          replaceUrl: true\n        })\n        .then(() => this.drive.setBusy(false));\n    }\n  }\n\n  setBusy(busy: boolean) {\n    this.drive.setBusy(busy);\n  }\n\n  refresh() {\n    this.tileList()?.refresh();\n    this.drive.setSelection([]);\n  }\n\n  onLayoutSettingsChange(e: any) {\n    this.#appCache.setItem(this.#LAYOUT_SETTINGS_STORAGE_KEY, e).subscribe();\n  }\n\n  #applyLayoutSettings(settings: SplitViewLayoutSettings) {\n    this.splitViewCmp().applyLayoutSettings(settings);\n  }\n\n  ngAfterViewInit(): void {\n    this.#appCache.getItem(this.#LAYOUT_SETTINGS_STORAGE_KEY).subscribe({\n      next: (ls: SplitViewLayoutSettings) => {\n        if (ls) {\n          this.enableDetails.set(ls.areas[2]?.visible);\n          this.enableTree.set(ls.areas[0]?.visible);\n          this.#applyLayoutSettings(ls);\n        }\n      }\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.clipboard.clear(APP_ID);\n  }\n}\n","<header>\n  <!-- navigation bar -->\n  <nav [attr.aria-label]=\"'yuv.app.drive.files.naviagtion.aria.label' | translate\">\n    <div class=\"nav\">\n      <button class=\"back\" [disabled]=\"!currentFolder\" title=\"{{ 'yuv.app.drive.files.nav.back.tooltip' | translate }}\" (click)=\"openParent()\">\n        <yvc-icon [svg]=\"icons.back\"></yvc-icon>\n      </button>\n      <button class=\"refresh\" title=\"{{ 'yuv.app.drive.files.nav.refresh.tooltip' | translate }}\" (click)=\"refresh()\">\n        <yvc-icon [svg]=\"icons.refresh\"></yvc-icon>\n      </button>\n    </div>\n\n    @if (!query()?.term) {\n      <ymd-breadcrumb></ymd-breadcrumb>\n    } @else {\n      <div class=\"breadcrumb\"></div>\n    }\n    <div class=\"search\">\n      <yuv-simple-search [query]=\"query()\" (querySubmit)=\"onQuerySubmit($event)\"></yuv-simple-search>\n      <!-- TODO: enable again once drive search needs to be a little bit more sophisticated -->\n      <!-- <ymd-drive-search (focused)=\"searchFocused = $event\"></ymd-drive-search> -->\n    </div>\n  </nav>\n\n  <!-- ribbon with actions and options -->\n  <ymd-ribbon [objects]=\"selection()\" [busy]=\"busy()\" [enableClipboard]=\"true\">\n    <ng-template #primaryActions>\n      <ymd-add-button [disabled]=\"disableCreate\"></ymd-add-button>\n    </ng-template>\n\n    <ng-template #secondaryActions>\n      <div class=\"options\">\n        @if (!smallScreenLayout()) {\n          <button\n            class=\"toggle-tree toggle\"\n            [ngClass]=\"{ enabled: enableTree() }\"\n            title=\"{{ 'yuv.app.drive.files.toggletree.tooltip' | translate }}\"\n            (click)=\"enableTree.set(!enableTree())\"\n          >\n            <yvc-icon [svg]=\"icons.toggleLeft\"></yvc-icon>\n          </button>\n          <button\n            class=\"toggle-details toggle\"\n            [ngClass]=\"{ enabled: enableDetails() }\"\n            title=\"{{ 'yuv.app.drive.files.toggledetails.tooltip' | translate }}\"\n            (click)=\"enableDetails.set(!enableDetails())\"\n          >\n            <yvc-icon [svg]=\"icons.toggleRight\"></yvc-icon>\n          </button>\n        }\n        <yuv-tile-config-trigger\n          [icon]=\"icons.settings\"\n          [bucket]=\"objectConfigBucket\"\n          [bucketLabel]=\"tileConfigBucketLabel\"\n          [options]=\"tileListOptions\"\n        ></yuv-tile-config-trigger>\n      </div>\n    </ng-template>\n  </ymd-ribbon>\n</header>\n\n<yvc-split-view [gutterSize]=\"1\" (layoutSettingsChange)=\"onLayoutSettingsChange($event)\">\n  <!-- folder tree -->\n  <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableTree() && !smallScreenLayout()\">\n    <ymd-folder-tree yuvFocusable=\"Tree\"></ymd-folder-tree>\n  </ng-template>\n\n  <!-- files -->\n  <ng-template yvcSplitArea [size]=\"60\">\n    @let err = error();\n    @if (err) {\n      <div class=\"error\">\n        <p>\n          <yvc-icon [svg]=\"icons.attention\"></yvc-icon>\n          @switch (err) {\n            @case (ERROR_CODE.NOT_FOUND) {\n              {{ 'yuv.app.drive.files.error.load.not-found' | translate }}\n            }\n            @case (ERROR_CODE.INVALID_ID) {\n              {{ 'yuv.app.drive.files.error.load.invalid-id' | translate }}\n            }\n            @default {\n              {{ 'yuv.app.drive.files.error.load' | translate }}\n            }\n          }\n        </p>\n      </div>\n    } @else {\n      <div class=\"files\" [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.label' | translate }\" (fileDrop)=\"onFileDrop($event)\">\n        <header class=\"files-header\">\n          <h1>{{ queryTitle() }}</h1>\n          @if (query()?.term) {\n            <ymd-search-filter [query]=\"query()\" (queryChange)=\"onFilterQueryChange($event)\"></ymd-search-filter>\n          }\n          @if (sortOptionsAvailable()) {\n            <ymd-sort />\n          }\n          <div class=\"flavors\">\n            <!-- TODO: enable again once flavors/aspects are supported -->\n            <!--  @for (f of flavorChips; track f.id) {\n            <yuv-flavor-chip [ngClass]=\"{ active: f.id === appliedFlavor?.id }\" [flavor]=\"f\" (click)=\"appliedFlavor = f\"></yuv-flavor-chip>\n          }-->\n          </div>\n        </header>\n\n        <yuv-tile-list\n          #tileList\n          class=\"staggered\"\n          [attr.aria-label]=\"'yuv.app.drive.files.content.aria.label' | translate\"\n          [attr.aria-busy]=\"busy()\"\n          [attr.role]=\"'listbox'\"\n          (keydown.delete)=\"onDelete()\"\n          [bucket]=\"objectConfigBucket\"\n          [multiselect]=\"true\"\n          [query]=\"query()\"\n          [flavor]=\"appliedFlavor\"\n          [options]=\"tileListOptions\"\n          (itemDblClick)=\"itemDoubleClicked($event)\"\n          (itemSelect)=\"itemClicked($event)\"\n          (selectionChange)=\"selectionChanged($event)\"\n          (copy)=\"onCopy($event)\"\n          (cut)=\"onCut($event)\"\n          (busy)=\"setBusy($event)\"\n          (ctxMenu)=\"onContextmenu($event)\"\n          [highlights]=\"highlightStyles$ | async\"\n        >\n          <div #empty>\n            @if (emptyMode() === 'root') {\n              <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.root.list' | translate }}</p>\n            } @else if (emptyMode() === 'query') {\n              <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.query.list' | translate }}</p>\n            } @else {\n              <p class=\"empty\">{{ 'yuv.app.drive.files.content.empty.list' | translate }}</p>\n            }\n          </div>\n        </yuv-tile-list>\n      </div>\n    }\n  </ng-template>\n\n  <!-- details -->\n  <ng-template yvcSplitArea [size]=\"20\" [visible]=\"enableDetails()\">\n    @let selectedItem = selected();\n    @if (enableDetails() && selectedItem) {\n      @if (selectedItem?.isFolder) {\n        <yuv-object-summary [configType]=\"configTypeOptions['folder']\" [dmsObject]=\"selectedItem\"></yuv-object-summary>\n      } @else {\n        <yuv-object-summary\n          [configType]=\"configTypeOptions['file']\"\n          [dmsObject]=\"selectedItem\"\n          [yuvFileDropZone]=\"{ label: 'yuv.app.drive.files.dropzone.content.replace.label' | translate }\"\n          [fileDropDisabled]=\"fileDropSummaryDisabled()\"\n          (fileDrop)=\"onFileUpdateDrop($event)\"\n        ></yuv-object-summary>\n      }\n    } @else {\n      @let sel = selection();\n      @if (sel && sel.length > 0) {\n        <yuv-multi-object-summary [headline]=\"'yuv.app.drive.multiselected.details' | translate: { count: selection().length }\"></yuv-multi-object-summary>\n      } @else if (tileList()?.items?.length === 0) {\n        <!-- TODO: CHOULD HAVE A DIFFERENT MESSAGE FOR EMPTY RESULTS EMPTY FOR NOW -->\n        <div class=\"message\">{{ 'yuv.app.drive.empty.results.details.message' | translate }}</div>\n      } @else {\n        <div class=\"message\">{{ 'yuv.app.drive.unselected.details' | translate }}</div>\n      }\n    }\n  </ng-template>\n</yvc-split-view>\n"]}
|