@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.
Files changed (107) hide show
  1. package/README.md +47 -0
  2. package/esm2022/extensions/index.mjs +2 -0
  3. package/esm2022/extensions/lib/extensions.module.mjs +35 -0
  4. package/esm2022/extensions/lib/extensions.service.mjs +44 -0
  5. package/esm2022/extensions/lib/object-config.defaults.mjs +19 -0
  6. package/esm2022/extensions/yuuvis-app-drive-extensions.mjs +5 -0
  7. package/esm2022/index.mjs +5 -0
  8. package/esm2022/lib/actions/copy-link/copy-link.action.mjs +40 -0
  9. package/esm2022/lib/actions/index.mjs +7 -0
  10. package/esm2022/lib/actions/manage-versions/manage-versions.action.mjs +33 -0
  11. package/esm2022/lib/actions/manage-versions/manage-versions.component.mjs +105 -0
  12. package/esm2022/lib/actions/paste/paste.action.mjs +41 -0
  13. package/esm2022/lib/actions/rename/rename.action.mjs +31 -0
  14. package/esm2022/lib/actions/rename/rename.component.mjs +42 -0
  15. package/esm2022/lib/actions/rename/rename.validator.mjs +23 -0
  16. package/esm2022/lib/actions/updateContent/update.content.action.mjs +52 -0
  17. package/esm2022/lib/components/add-button/add-button-overlay/add-button-overlay.component.mjs +109 -0
  18. package/esm2022/lib/components/add-button/add-button.component.mjs +39 -0
  19. package/esm2022/lib/components/breadcrumb/breadcrumb.component.mjs +74 -0
  20. package/esm2022/lib/components/folder-tree/folder-tree.component.mjs +89 -0
  21. package/esm2022/lib/components/index.mjs +10 -0
  22. package/esm2022/lib/components/object-name/object-name.component.mjs +60 -0
  23. package/esm2022/lib/components/overlay/create-folder/create-folder.component.mjs +48 -0
  24. package/esm2022/lib/components/paste-from-clipboard/paste-from-clipboard.component.mjs +28 -0
  25. package/esm2022/lib/components/ribbon/ribbon.component.mjs +102 -0
  26. package/esm2022/lib/components/search-filter/date-range-picker/date-range-picker.component.mjs +38 -0
  27. package/esm2022/lib/components/search-filter/search-filter.component.mjs +429 -0
  28. package/esm2022/lib/components/sort/sort.component.mjs +156 -0
  29. package/esm2022/lib/components/versions-list/tile/tile.component.mjs +60 -0
  30. package/esm2022/lib/components/versions-list/versions-list.component.mjs +94 -0
  31. package/esm2022/lib/container/drive/drive.component.mjs +116 -0
  32. package/esm2022/lib/drive.icons.mjs +16 -0
  33. package/esm2022/lib/drive.schema.mjs +49 -0
  34. package/esm2022/lib/lib.routes.mjs +17 -0
  35. package/esm2022/lib/pages/files/files.component.mjs +377 -0
  36. package/esm2022/lib/pages/object/object.component.mjs +200 -0
  37. package/esm2022/lib/services/drive/drive.interface.mjs +14 -0
  38. package/esm2022/lib/services/drive/drive.service.mjs +437 -0
  39. package/esm2022/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.component.mjs +158 -0
  40. package/esm2022/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.interface.mjs +2 -0
  41. package/esm2022/lib/services/drive/versions/versions.mapping.mjs +42 -0
  42. package/esm2022/lib/services/index.mjs +5 -0
  43. package/esm2022/lib/services/providers/drive.providers.mjs +10 -0
  44. package/esm2022/lib/services/resolver/files.resolver.mjs +12 -0
  45. package/esm2022/lib/services/resolver/index.mjs +3 -0
  46. package/esm2022/lib/services/resolver/versions.route.resolver.mjs +10 -0
  47. package/esm2022/lib/services/stored-query/stored-query.data.mjs +25 -0
  48. package/esm2022/lib/services/stored-query/stored-query.interface.mjs +2 -0
  49. package/esm2022/lib/services/stored-query/stored-query.service.mjs +41 -0
  50. package/esm2022/lib/services/tokens/breadcrumb-max-depth.token.mjs +3 -0
  51. package/esm2022/lib/services/tokens/index.mjs +2 -0
  52. package/esm2022/yuuvis-app-drive.mjs +5 -0
  53. package/extensions/README.md +3 -0
  54. package/extensions/index.d.ts +1 -0
  55. package/extensions/lib/extensions.module.d.ts +6 -0
  56. package/extensions/lib/extensions.service.d.ts +7 -0
  57. package/extensions/lib/object-config.defaults.d.ts +2 -0
  58. package/fesm2022/yuuvis-app-drive-extensions.mjs +99 -0
  59. package/fesm2022/yuuvis-app-drive-extensions.mjs.map +1 -0
  60. package/fesm2022/yuuvis-app-drive.mjs +2945 -0
  61. package/fesm2022/yuuvis-app-drive.mjs.map +1 -0
  62. package/index.d.ts +4 -0
  63. package/lib/actions/copy-link/copy-link.action.d.ts +18 -0
  64. package/lib/actions/index.d.ts +6 -0
  65. package/lib/actions/manage-versions/manage-versions.action.d.ts +17 -0
  66. package/lib/actions/manage-versions/manage-versions.component.d.ts +32 -0
  67. package/lib/actions/paste/paste.action.d.ts +17 -0
  68. package/lib/actions/rename/rename.action.d.ts +17 -0
  69. package/lib/actions/rename/rename.component.d.ts +12 -0
  70. package/lib/actions/rename/rename.validator.d.ts +5 -0
  71. package/lib/actions/updateContent/update.content.action.d.ts +18 -0
  72. package/lib/components/add-button/add-button-overlay/add-button-overlay.component.d.ts +26 -0
  73. package/lib/components/add-button/add-button.component.d.ts +12 -0
  74. package/lib/components/breadcrumb/breadcrumb.component.d.ts +25 -0
  75. package/lib/components/folder-tree/folder-tree.component.d.ts +13 -0
  76. package/lib/components/index.d.ts +8 -0
  77. package/lib/components/object-name/object-name.component.d.ts +21 -0
  78. package/lib/components/overlay/create-folder/create-folder.component.d.ts +12 -0
  79. package/lib/components/paste-from-clipboard/paste-from-clipboard.component.d.ts +13 -0
  80. package/lib/components/ribbon/ribbon.component.d.ts +24 -0
  81. package/lib/components/search-filter/date-range-picker/date-range-picker.component.d.ts +13 -0
  82. package/lib/components/search-filter/search-filter.component.d.ts +23 -0
  83. package/lib/components/sort/sort.component.d.ts +31 -0
  84. package/lib/components/versions-list/tile/tile.component.d.ts +14 -0
  85. package/lib/components/versions-list/versions-list.component.d.ts +17 -0
  86. package/lib/container/drive/drive.component.d.ts +36 -0
  87. package/lib/drive.icons.d.ts +15 -0
  88. package/lib/drive.schema.d.ts +23 -0
  89. package/lib/lib.routes.d.ts +2 -0
  90. package/lib/pages/files/files.component.d.ts +101 -0
  91. package/lib/pages/object/object.component.d.ts +35 -0
  92. package/lib/services/drive/drive.interface.d.ts +62 -0
  93. package/lib/services/drive/drive.service.d.ts +64 -0
  94. package/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.component.d.ts +31 -0
  95. package/lib/services/drive/resolve-name-conflicts/resolve-name-conflicts.interface.d.ts +8 -0
  96. package/lib/services/drive/versions/versions.mapping.d.ts +2 -0
  97. package/lib/services/index.d.ts +4 -0
  98. package/lib/services/providers/drive.providers.d.ts +7 -0
  99. package/lib/services/resolver/files.resolver.d.ts +2 -0
  100. package/lib/services/resolver/index.d.ts +2 -0
  101. package/lib/services/resolver/versions.route.resolver.d.ts +2 -0
  102. package/lib/services/stored-query/stored-query.data.d.ts +5 -0
  103. package/lib/services/stored-query/stored-query.interface.d.ts +5 -0
  104. package/lib/services/stored-query/stored-query.service.d.ts +10 -0
  105. package/lib/services/tokens/breadcrumb-max-depth.token.d.ts +2 -0
  106. package/lib/services/tokens/index.d.ts +1 -0
  107. 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"]}