mdi-folder
- {{ wrapped.item.label }}
+ {{ wrapped.item.properties.label || String(wrapped.item.identifier ?? '') }}
—
-
{{ formatDate(wrapped.item.modifiedOn) }}
+
{{ formatDate(wrapped.item.modified) }}
- {{ getFileIcon(wrapped.item as FileEntityObject) }}
- {{ wrapped.item.label }}
+ {{ getFileIcon(wrapped.item as EntityObject) }}
+ {{ wrapped.item.properties.label || String(wrapped.item.identifier ?? '') }}
- {{ formatSize((wrapped.item as FileEntityObject).size) }}
- {{ formatDate(wrapped.item.modifiedOn) }}
+ {{ formatSize(wrapped.item.properties.size) }}
+ {{ formatDate(wrapped.item.modified) }}
-import { FileCollectionObject } from '@FilesManager/models/collection'
-import { FileEntityObject } from '@FilesManager/models/entity'
+import { CollectionObject } from '@DocumentsManager/models/collection'
+import { EntityObject } from '@DocumentsManager/models/entity'
import { getFileIcon, formatSize } from '@/utils/fileHelpers'
import { FileActionsMenu } from '@/components'
defineProps<{
- collections: FileCollectionObject[]
- entities: FileEntityObject[]
+ collections: CollectionObject[]
+ entities: EntityObject[]
selectedIds: Set
}>()
const emit = defineEmits<{
- 'item-click': [item: FileCollectionObject | FileEntityObject, event: MouseEvent | KeyboardEvent]
- 'rename': [item: FileCollectionObject | FileEntityObject]
- 'delete': [item: FileCollectionObject | FileEntityObject]
- 'download': [item: FileCollectionObject | FileEntityObject]
- 'show-details': [item: FileCollectionObject | FileEntityObject]
+ 'item-click': [item: CollectionObject | EntityObject, event: MouseEvent | KeyboardEvent]
+ 'open': [item: CollectionObject | EntityObject]
+ 'rename': [item: CollectionObject | EntityObject]
+ 'delete': [item: CollectionObject | EntityObject]
+ 'download': [item: CollectionObject | EntityObject]
+ 'show-details': [item: CollectionObject | EntityObject]
}>()
@@ -24,9 +25,9 @@ const emit = defineEmits<{
@@ -34,6 +35,7 @@ const emit = defineEmits<{
:item="folder"
size="x-small"
button-class="action-btn"
+ @open="emit('open', $event)"
@rename="emit('rename', $event)"
@delete="emit('delete', $event)"
@download="emit('download', $event)"
@@ -41,22 +43,24 @@ const emit = defineEmits<{
/>
mdi-folder
-
{{ folder.label }}
+
{{ folder.properties.label || String(folder.identifier ?? '') }}
{{ getFileIcon(entity) }}
-
{{ entity.label }}
-
{{ formatSize(entity.size) }}
+
{{ entity.properties.label || String(entity.identifier ?? '') }}
+
{{ formatSize(entity.properties.size) }}
diff --git a/src/components/views/FilesListView.vue b/src/components/views/FilesListView.vue
index f06caa0..0512fb8 100644
--- a/src/components/views/FilesListView.vue
+++ b/src/components/views/FilesListView.vue
@@ -1,27 +1,28 @@
@@ -45,16 +46,17 @@ function isCollection(wrapped: ItemWithType): wrapped is { item: FileCollectionO
emit('item-click', wrapped.item, $event)"
>
mdi-folder
- {{ wrapped.item.label }}
+ {{ wrapped.item.properties.label || String(wrapped.item.identifier ?? '') }}
emit('item-click', wrapped.item, $event)"
+ @dblclick.stop="emit('open', wrapped.item)"
>
- {{ getFileIcon(wrapped.item as FileEntityObject) }}
+ {{ getFileIcon(wrapped.item as EntityObject) }}
- {{ wrapped.item.label }}
- {{ formatSize((wrapped.item as FileEntityObject).size) }}
+ {{ wrapped.item.properties.label || String(wrapped.item.identifier ?? '') }}
+ {{ formatSize(wrapped.item.properties.size) }}
= ref(ROOT_ID)
// Loading/error state
- const isLoading = computed(() => nodesStore.loading)
+ const isLoading = computed(() => nodesStore.transceiving)
const error = computed(() => nodesStore.error)
// Provider and service
- const provider = computed(() => providersStore.getProvider(providerId))
- const service = computed(() => servicesStore.getService(providerId, serviceId))
- const rootId = computed(() => servicesStore.getRootId(providerId, serviceId) || ROOT_ID)
+ const provider = computed(() => providersStore.provider(providerId))
+ const service = computed(() => servicesStore.service(providerId, serviceId))
+ const rootId = computed(() => ROOT_ID)
// Current children
const currentChildren = computed(() =>
nodesStore.getChildren(providerId, serviceId, currentLocation.value)
)
- const currentCollections: ComputedRef = computed(() =>
+ const currentCollections: ComputedRef = computed(() =>
nodesStore.getChildCollections(providerId, serviceId, currentLocation.value)
)
- const currentEntities: ComputedRef = computed(() =>
+ const currentEntities: ComputedRef = computed(() =>
nodesStore.getChildEntities(providerId, serviceId, currentLocation.value)
)
@@ -77,7 +78,7 @@ export function useFileManager(options: UseFileManagerOptions) {
}
const currentNode = nodesStore.getNode(providerId, serviceId, currentLocation.value)
if (currentNode) {
- await navigateTo(currentNode.in || ROOT_ID)
+ await navigateTo(currentNode.collection ? String(currentNode.collection) : ROOT_ID)
}
}
@@ -88,15 +89,14 @@ export function useFileManager(options: UseFileManagerOptions) {
// Refresh current location
const refresh = async (
- filter?: FilterCondition[] | null,
- sort?: SortCondition[] | null,
- range?: RangeCondition | null
+ filter?: ListFilter,
+ sort?: ListSort,
+ range?: ListRange
) => {
await nodesStore.fetchNodes(
providerId,
serviceId,
- currentLocation.value === ROOT_ID ? null : currentLocation.value,
- false,
+ currentLocation.value === ROOT_ID ? ROOT_ID : currentLocation.value,
filter,
sort,
range
@@ -104,12 +104,12 @@ export function useFileManager(options: UseFileManagerOptions) {
}
// Create a new folder
- const createFolder = async (label: string): Promise => {
+ const createFolder = async (label: string): Promise => {
return await nodesStore.createCollection(
providerId,
serviceId,
currentLocation.value === ROOT_ID ? ROOT_ID : currentLocation.value,
- { label }
+ { label, owner: '' }
)
}
@@ -117,12 +117,22 @@ export function useFileManager(options: UseFileManagerOptions) {
const createFile = async (
label: string,
mime: string = 'application/octet-stream'
- ): Promise => {
+ ): Promise => {
+ const properties: DocumentInterface = {
+ '@type': 'documents.properties',
+ urid: null,
+ size: 0,
+ label,
+ mime,
+ format: null,
+ encoding: null,
+ }
+
return await nodesStore.createEntity(
providerId,
serviceId,
currentLocation.value === ROOT_ID ? ROOT_ID : currentLocation.value,
- { label, mime }
+ properties
)
}
@@ -133,10 +143,22 @@ export function useFileManager(options: UseFileManagerOptions) {
throw new Error('Node not found')
}
- if (node['@type'] === 'files.collection') {
- return await nodesStore.modifyCollection(providerId, serviceId, nodeId, { label: newLabel })
+ if (node instanceof CollectionObject) {
+ return await nodesStore.updateCollection(providerId, serviceId, nodeId, {
+ label: newLabel,
+ owner: node.properties.owner,
+ })
} else {
- return await nodesStore.modifyEntity(providerId, serviceId, node.in, nodeId, { label: newLabel })
+ const properties: DocumentInterface = {
+ '@type': 'documents.properties',
+ urid: node.properties.urid,
+ size: node.properties.size,
+ label: newLabel,
+ mime: node.properties.mime,
+ format: node.properties.format,
+ encoding: node.properties.encoding,
+ }
+ return await nodesStore.updateEntity(providerId, serviceId, node.collection, nodeId, properties)
}
}
@@ -147,61 +169,35 @@ export function useFileManager(options: UseFileManagerOptions) {
throw new Error('Node not found')
}
- if (node['@type'] === 'files.collection') {
- return await nodesStore.destroyCollection(providerId, serviceId, nodeId)
+ if (node instanceof CollectionObject) {
+ return await nodesStore.deleteCollection(providerId, serviceId, nodeId)
} else {
- return await nodesStore.destroyEntity(providerId, serviceId, node.in, nodeId)
- }
- }
-
- // Copy a node
- const copyNode = async (nodeId: string, destinationId?: string | null) => {
- const node = nodesStore.getNode(providerId, serviceId, nodeId)
- if (!node) {
- throw new Error('Node not found')
- }
-
- const destination = destinationId ?? currentLocation.value
-
- if (node['@type'] === 'files.collection') {
- return await nodesStore.copyCollection(providerId, serviceId, nodeId, destination)
- } else {
- return await nodesStore.copyEntity(providerId, serviceId, node.in, nodeId, destination)
- }
- }
-
- // Move a node
- const moveNode = async (nodeId: string, destinationId?: string | null) => {
- const node = nodesStore.getNode(providerId, serviceId, nodeId)
- if (!node) {
- throw new Error('Node not found')
- }
-
- const destination = destinationId ?? currentLocation.value
-
- if (node['@type'] === 'files.collection') {
- return await nodesStore.moveCollection(providerId, serviceId, nodeId, destination)
- } else {
- return await nodesStore.moveEntity(providerId, serviceId, node.in, nodeId, destination)
+ return await nodesStore.deleteEntity(providerId, serviceId, node.collection, nodeId)
}
}
// Read file content
const readFile = async (entityId: string): Promise => {
const node = nodesStore.getNode(providerId, serviceId, entityId)
- if (!node || node['@type'] !== 'files.entity') {
+ if (!node || !(node instanceof EntityObject)) {
throw new Error('Entity not found')
}
- return await nodesStore.readEntity(providerId, serviceId, node.in || ROOT_ID, entityId)
+ return await nodesStore.readEntity(providerId, serviceId, node.collection || ROOT_ID, entityId)
}
// Write file content
const writeFile = async (entityId: string, content: string): Promise => {
const node = nodesStore.getNode(providerId, serviceId, entityId)
- if (!node || node['@type'] !== 'files.entity') {
+ if (!node || !(node instanceof EntityObject)) {
throw new Error('Entity not found')
}
- return await nodesStore.writeEntity(providerId, serviceId, node.in, entityId, content)
+ return await nodesStore.writeEntity(providerId, serviceId, node.collection, entityId, content)
+ }
+
+ // Get a URL suitable for inline viewing (img src / video src)
+ const getEntityUrl = (entityId: string, collectionId?: string | null): string => {
+ const collection = collectionId ?? currentLocation.value
+ return `${TRANSFER_BASE_URL}/download/entity/${encodeURIComponent(providerId)}/${encodeURIComponent(serviceId)}/${encodeURIComponent(collection)}/${encodeURIComponent(entityId)}`
}
// Download a single file
@@ -214,7 +210,6 @@ export function useFileManager(options: UseFileManagerOptions) {
window.open(url, '_blank')
}
- // Download a collection (folder) as ZIP
const downloadCollection = (collectionId: string): void => {
// Use path parameters: /download/collection/{provider}/{service}/{identifier}
const url = `${TRANSFER_BASE_URL}/download/collection/${encodeURIComponent(providerId)}/${encodeURIComponent(serviceId)}/${encodeURIComponent(collectionId)}`
@@ -222,7 +217,6 @@ export function useFileManager(options: UseFileManagerOptions) {
window.open(url, '_blank')
}
- // Download multiple items as ZIP archive
const downloadArchive = (ids: string[], name: string = 'download', collectionId?: string | null): void => {
const collection = collectionId ?? currentLocation.value
const params = new URLSearchParams({
@@ -244,12 +238,8 @@ export function useFileManager(options: UseFileManagerOptions) {
// Initialize - fetch providers, services, and initial nodes if autoFetch
const initialize = async () => {
- if (!providersStore.initialized) {
- await providersStore.fetchProviders()
- }
- if (!servicesStore.initialized) {
- await servicesStore.fetchServices()
- }
+ await providersStore.list()
+ await servicesStore.list({ [providerId]: true })
if (autoFetch) {
await refresh()
}
@@ -284,10 +274,9 @@ export function useFileManager(options: UseFileManagerOptions) {
createFile,
renameNode,
deleteNode,
- copyNode,
- moveNode,
readFile,
writeFile,
+ getEntityUrl,
downloadEntity,
downloadCollection,
downloadArchive,
diff --git a/src/composables/useFileSelection.ts b/src/composables/useFileSelection.ts
index 259b0d0..8e6a149 100644
--- a/src/composables/useFileSelection.ts
+++ b/src/composables/useFileSelection.ts
@@ -5,10 +5,10 @@
import { ref, computed } from 'vue'
import type { Ref, ComputedRef } from 'vue'
-import { FileCollectionObject } from '@FilesManager/models/collection'
-import { FileEntityObject } from '@FilesManager/models/entity'
+import { CollectionObject } from '@DocumentsManager/models/collection'
+import { EntityObject } from '@DocumentsManager/models/entity'
-type NodeRecord = FileCollectionObject | FileEntityObject
+type NodeRecord = CollectionObject | EntityObject
export interface UseFileSelectionOptions {
multiple?: boolean
@@ -17,148 +17,110 @@ export interface UseFileSelectionOptions {
}
export function useFileSelection(options: UseFileSelectionOptions = {}) {
- const {
- multiple = true,
- allowFolders = true,
- allowFiles = true
+ const {
+ multiple = true,
+ allowFolders = true,
+ allowFiles = true,
} = options
const selectedIds: Ref> = ref(new Set())
const selectedNodes: Ref
diff --git a/src/routes.ts b/src/routes.ts
index 426f25e..3692806 100644
--- a/src/routes.ts
+++ b/src/routes.ts
@@ -2,8 +2,8 @@ import type { RouteRecordRaw } from 'vue-router'
const routes: RouteRecordRaw[] = [
{
- name: 'files',
- path: '/files',
+ name: 'documents',
+ path: '/',
component: () => import('@/pages/FilesPage.vue')
},
]
diff --git a/src/stores/documentsStore.ts b/src/stores/documentsStore.ts
new file mode 100644
index 0000000..b18fddd
--- /dev/null
+++ b/src/stores/documentsStore.ts
@@ -0,0 +1,222 @@
+import { computed, ref } from 'vue'
+import { defineStore } from 'pinia'
+import { useProvidersStore, useServicesStore, useNodesStore, ROOT_ID } from '@DocumentsManager/stores'
+import { CollectionObject } from '@DocumentsManager/models/collection'
+import { EntityObject } from '@DocumentsManager/models/entity'
+import type { SortField, SortOrder, ViewMode, BreadcrumbItem } from '@/types'
+
+type NodeRecord = CollectionObject | EntityObject
+
+export const useDocumentsStore = defineStore('documentsStore', () => {
+ const providersStore = useProvidersStore()
+ const servicesStore = useServicesStore()
+ const nodesStore = useNodesStore()
+
+ const activeProviderId = ref('default')
+ const activeServiceId = ref
('personal')
+ const currentLocation = ref(ROOT_ID)
+
+ const viewMode = ref('grid')
+ const sortField = ref('label')
+ const sortOrder = ref('asc')
+ const searchQuery = ref('')
+ const sidebarVisible = ref(true)
+
+ const transceiving = computed(() =>
+ providersStore.transceiving || servicesStore.transceiving || nodesStore.transceiving,
+ )
+
+ const provider = computed(() => providersStore.provider(activeProviderId.value))
+ const service = computed(() => servicesStore.service(activeProviderId.value, activeServiceId.value))
+
+ const currentCollections = computed(() =>
+ nodesStore.getChildCollections(activeProviderId.value, activeServiceId.value, currentLocation.value),
+ )
+
+ const currentEntities = computed(() =>
+ nodesStore.getChildEntities(activeProviderId.value, activeServiceId.value, currentLocation.value),
+ )
+
+ const breadcrumbs = computed(() => {
+ const nodes = nodesStore.getPath(activeProviderId.value, activeServiceId.value, currentLocation.value)
+ return [
+ { id: ROOT_ID, label: 'Home', isRoot: true },
+ ...nodes.map((node) => ({
+ id: String(node.identifier),
+ label: node.properties.label,
+ isRoot: false,
+ })),
+ ]
+ })
+
+ function sortCollections(items: CollectionObject[]): CollectionObject[] {
+ return [...items].sort((a, b) => {
+ const aVal = sortField.value === 'label'
+ ? a.properties.label
+ : sortField.value === 'modifiedOn'
+ ? (a.modified?.getTime() ?? 0)
+ : sortField.value === 'createdOn'
+ ? (a.created?.getTime() ?? 0)
+ : ''
+ const bVal = sortField.value === 'label'
+ ? b.properties.label
+ : sortField.value === 'modifiedOn'
+ ? (b.modified?.getTime() ?? 0)
+ : sortField.value === 'createdOn'
+ ? (b.created?.getTime() ?? 0)
+ : ''
+
+ const cmp = String(aVal).localeCompare(String(bVal))
+ return sortOrder.value === 'asc' ? cmp : -cmp
+ })
+ }
+
+ function sortEntities(items: EntityObject[]): EntityObject[] {
+ return [...items].sort((a, b) => {
+ const aVal = sortField.value === 'label'
+ ? a.properties.label
+ : sortField.value === 'mime'
+ ? (a.properties.mime ?? '')
+ : sortField.value === 'size'
+ ? a.properties.size
+ : sortField.value === 'modifiedOn'
+ ? (a.modified?.getTime() ?? 0)
+ : sortField.value === 'createdOn'
+ ? (a.created?.getTime() ?? 0)
+ : ''
+ const bVal = sortField.value === 'label'
+ ? b.properties.label
+ : sortField.value === 'mime'
+ ? (b.properties.mime ?? '')
+ : sortField.value === 'size'
+ ? b.properties.size
+ : sortField.value === 'modifiedOn'
+ ? (b.modified?.getTime() ?? 0)
+ : sortField.value === 'createdOn'
+ ? (b.created?.getTime() ?? 0)
+ : ''
+
+ const cmp = String(aVal).localeCompare(String(bVal))
+ return sortOrder.value === 'asc' ? cmp : -cmp
+ })
+ }
+
+ function filterNode(node: NodeRecord): boolean {
+ if (!searchQuery.value) return true
+ return node.properties.label.toLowerCase().includes(searchQuery.value.toLowerCase())
+ }
+
+ const sortedItems = computed(() => ({
+ collections: sortCollections(currentCollections.value).filter(filterNode),
+ entities: sortEntities(currentEntities.value).filter(filterNode),
+ }))
+
+ const hasItems = computed(() =>
+ sortedItems.value.collections.length > 0 || sortedItems.value.entities.length > 0,
+ )
+
+ const isAtRoot = computed(() => currentLocation.value === ROOT_ID)
+
+ async function initialize() {
+ await providersStore.list()
+ await servicesStore.list({ [activeProviderId.value]: true })
+ await refresh()
+ }
+
+ async function refresh() {
+ await nodesStore.fetchNodes(activeProviderId.value, activeServiceId.value, currentLocation.value)
+ }
+
+ async function navigateTo(collectionId: string | null) {
+ currentLocation.value = collectionId || ROOT_ID
+ await refresh()
+ }
+
+ async function navigateToRoot() {
+ await navigateTo(ROOT_ID)
+ }
+
+ async function navigateUp() {
+ if (currentLocation.value === ROOT_ID) return
+ const currentNode = nodesStore.getNode(activeProviderId.value, activeServiceId.value, currentLocation.value)
+ if (!currentNode) return
+ const parentId = currentNode.collection ? String(currentNode.collection) : ROOT_ID
+ await navigateTo(parentId)
+ }
+
+ async function createFolder(label: string) {
+ await nodesStore.createCollection(
+ activeProviderId.value,
+ activeServiceId.value,
+ currentLocation.value,
+ { label, owner: '' },
+ )
+ await refresh()
+ }
+
+ async function renameNode(node: NodeRecord, label: string) {
+ if (node instanceof CollectionObject) {
+ await nodesStore.updateCollection(
+ activeProviderId.value,
+ activeServiceId.value,
+ node.identifier,
+ { label, owner: node.properties.owner },
+ )
+ } else {
+ await nodesStore.updateEntity(
+ activeProviderId.value,
+ activeServiceId.value,
+ node.collection,
+ node.identifier,
+ {
+ '@type': 'documents.properties',
+ urid: node.properties.urid,
+ size: node.properties.size,
+ label,
+ mime: node.properties.mime,
+ format: node.properties.format,
+ encoding: node.properties.encoding,
+ },
+ )
+ }
+ await refresh()
+ }
+
+ async function deleteNode(node: NodeRecord) {
+ if (node instanceof CollectionObject) {
+ await nodesStore.deleteCollection(activeProviderId.value, activeServiceId.value, node.identifier)
+ } else {
+ await nodesStore.deleteEntity(activeProviderId.value, activeServiceId.value, node.collection, node.identifier)
+ }
+ await refresh()
+ }
+
+ return {
+ activeProviderId,
+ activeServiceId,
+ currentLocation,
+ viewMode,
+ sortField,
+ sortOrder,
+ searchQuery,
+ sidebarVisible,
+ transceiving,
+ provider,
+ service,
+ currentCollections,
+ currentEntities,
+ sortedItems,
+ hasItems,
+ breadcrumbs,
+ isAtRoot,
+ initialize,
+ refresh,
+ navigateTo,
+ navigateToRoot,
+ navigateUp,
+ createFolder,
+ renameNode,
+ deleteNode,
+ ROOT_ID,
+ }
+})
diff --git a/src/stores/index.ts b/src/stores/index.ts
new file mode 100644
index 0000000..ba32d18
--- /dev/null
+++ b/src/stores/index.ts
@@ -0,0 +1 @@
+export { useDocumentsStore } from './documentsStore'
diff --git a/src/types/index.ts b/src/types/index.ts
index 627d1e0..92f6228 100644
--- a/src/types/index.ts
+++ b/src/types/index.ts
@@ -28,3 +28,23 @@ export interface ContextMenuAction {
disabled?: boolean
divider?: boolean
}
+
+/**
+ * Shape of an item registered at the `documents_file_viewer` integration point.
+ * Stored under `meta` so it fits inside a standard `ModuleIntegrationItem`.
+ */
+export interface DocumentViewerMeta {
+ /** Exact MIME type matches, e.g. ['application/pdf'] */
+ mimeTypes?: string[]
+ /** Glob-style patterns, e.g. ['image/*', 'video/*'] */
+ mimePatterns?: string[]
+}
+
+export interface DocumentViewerItem {
+ id: string
+ label?: string
+ priority?: number
+ meta: DocumentViewerMeta
+ /** Async factory returning the Vue viewer component */
+ component: () => Promise
+}
diff --git a/src/utils/fileHelpers.ts b/src/utils/fileHelpers.ts
index 84ea19b..c59c538 100644
--- a/src/utils/fileHelpers.ts
+++ b/src/utils/fileHelpers.ts
@@ -1,10 +1,10 @@
-import { FileEntityObject } from '@FilesManager/models/entity'
+import { EntityObject } from '@DocumentsManager/models/entity'
/**
* Get the appropriate icon for a file based on its MIME type
*/
-export function getFileIcon(entity: FileEntityObject): string {
- const mime = entity.mime || ''
+export function getFileIcon(entity: EntityObject): string {
+ const mime = entity.properties.mime || ''
if (!mime) return 'mdi-file'
if (mime.startsWith('image/')) return 'mdi-file-image'
if (mime.startsWith('video/')) return 'mdi-file-video'
@@ -22,19 +22,22 @@ export function getFileIcon(entity: FileEntityObject): string {
* Format file size in human readable format
*/
export function formatSize(bytes: number): string {
- if (bytes === 0) return '0 B'
+ const safeBytes = Number.isFinite(bytes) ? bytes : 0
+ if (safeBytes === 0) return '0 B'
const k = 1024
const sizes = ['B', 'KB', 'MB', 'GB', 'TB']
- const i = Math.floor(Math.log(bytes) / Math.log(k))
- return parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i]
+ const i = Math.floor(Math.log(safeBytes) / Math.log(k))
+ return parseFloat((safeBytes / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i]
}
/**
* Format date string to localized format
*/
-export function formatDate(dateStr: string): string {
- if (!dateStr) return '—'
- return new Date(dateStr).toLocaleDateString('en-US', {
+export function formatDate(value: Date | string | null | undefined): string {
+ if (!value) return '—'
+ const date = value instanceof Date ? value : new Date(value)
+ if (Number.isNaN(date.getTime())) return '—'
+ return date.toLocaleDateString('en-US', {
year: 'numeric',
month: 'short',
day: 'numeric',
diff --git a/tsconfig.app.json b/tsconfig.app.json
index da2be85..22087b9 100644
--- a/tsconfig.app.json
+++ b/tsconfig.app.json
@@ -7,14 +7,14 @@
"paths": {
"@/*": ["./src/*"],
"@KTXC/*": ["../../core/src/*"],
- "@FilesManager/*": ["../file_manager/src/*"]
+ "@DocumentsManager/*": ["../documents_manager/src/*"]
}
},
"include": [
"src/**/*.ts",
"src/**/*.tsx",
"src/**/*.vue",
- "../file_manager/src/**/*.ts",
+ "../documents_manager/src/**/*.ts",
"../../core/src/**/*.ts"
]
}
diff --git a/vite.config.ts b/vite.config.ts
index ada6914..cc29852 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -27,7 +27,7 @@ export default defineConfig({
alias: {
'@': path.resolve(__dirname, './src'),
'@KTXC': path.resolve(__dirname, '../../core/src'),
- '@filesManager': path.resolve(__dirname, '../files_manager/src'),
+ '@DocumentsManager': path.resolve(__dirname, '../documents_manager/src'),
},
},
build: {
@@ -45,19 +45,19 @@ export default defineConfig({
'vue-router',
'pinia',
'@KTXC',
- /^@FilesManager\//,
+ /^@DocumentsManager\//,
],
output: {
paths: (id) => {
if (id === '@KTXC') return '/js/ktxc.mjs'
- if (id.startsWith('@FilesManager/')) {
- return '/modules/file_manager/static/module.mjs'
+ if (id.startsWith('@DocumentsManager/')) {
+ return '/modules/documents_manager/static/module.mjs'
}
return id
},
assetFileNames: (assetInfo) => {
if (assetInfo.name?.endsWith('.css')) {
- return 'files-[hash].css'
+ return 'documents-[hash].css'
}
return '[name]-[hash][extname]'
}