Compare commits
2 Commits
ccad83b8ec
...
e84c665e7c
Author | SHA1 | Date | |
---|---|---|---|
![]() |
e84c665e7c | ||
![]() |
1b12ae86de |
@ -91,8 +91,7 @@
|
|||||||
}
|
}
|
||||||
.headermain,
|
.headermain,
|
||||||
.menu,
|
.menu,
|
||||||
.rename-button,
|
.rename-button {
|
||||||
.suggest-gallery {
|
|
||||||
display: none !important;
|
display: none !important;
|
||||||
}
|
}
|
||||||
.breadcrumb > a {
|
.breadcrumb > a {
|
||||||
|
@ -37,21 +37,24 @@ export class Doc {
|
|||||||
return this.url.replace(/^\/#/, '')
|
return this.url.replace(/^\/#/, '')
|
||||||
}
|
}
|
||||||
get img(): boolean {
|
get img(): boolean {
|
||||||
const ext = this.name.split('.').pop()?.toLowerCase() || ''
|
// Folders cannot be images
|
||||||
return ['jpg', 'jpeg', 'png', 'gif', 'webp', 'avif', 'heic', 'heif', 'svg'].includes(ext)
|
if (this.dir) return false
|
||||||
|
return ['jpg', 'jpeg', 'png', 'gif', 'webp', 'avif', 'heic', 'heif', 'svg'].includes(this.ext)
|
||||||
}
|
}
|
||||||
get previewable(): boolean {
|
get previewable(): boolean {
|
||||||
|
// Folders cannot be previewable
|
||||||
|
if (this.dir) return false
|
||||||
if (this.img) return true
|
if (this.img) return true
|
||||||
const ext = this.name.split('.').pop()?.toLowerCase() || ''
|
|
||||||
// Not a comprehensive list, but good enough for now
|
// Not a comprehensive list, but good enough for now
|
||||||
return ['mp4', 'mkv', 'webm', 'ogg', 'mp3', 'flac', 'aac', 'pdf'].includes(ext)
|
return ['mp4', 'mkv', 'webm', 'ogg', 'mp3', 'flac', 'aac', 'pdf'].includes(this.ext)
|
||||||
}
|
}
|
||||||
get previewurl(): string {
|
get previewurl(): string {
|
||||||
return this.url.replace(/^\/files/, '/preview')
|
return this.url.replace(/^\/files/, '/preview')
|
||||||
}
|
}
|
||||||
get ext(): string {
|
get ext(): string {
|
||||||
const ext = this.name.split('.').pop()
|
const dotIndex = this.name.lastIndexOf('.')
|
||||||
return ext ? ext.toLowerCase() : ''
|
if (dotIndex === -1 || dotIndex === this.name.length - 1) return ''
|
||||||
|
return this.name.slice(dotIndex + 1).toLowerCase()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export type errorEvent = {
|
export type errorEvent = {
|
||||||
|
@ -50,12 +50,11 @@ export function formatUnixDate(t: number) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function getFileExtension(filename: string) {
|
export function getFileExtension(filename: string) {
|
||||||
const parts = filename.split('.')
|
const dotIndex = filename.lastIndexOf('.')
|
||||||
if (parts.length > 1) {
|
if (dotIndex === -1 || dotIndex === filename.length - 1) {
|
||||||
return parts[parts.length - 1]
|
return '' // No extension
|
||||||
} else {
|
|
||||||
return '' // No hay extensión
|
|
||||||
}
|
}
|
||||||
|
return filename.slice(dotIndex + 1)
|
||||||
}
|
}
|
||||||
interface FileTypes {
|
interface FileTypes {
|
||||||
[key: string]: string[]
|
[key: string]: string[]
|
||||||
@ -68,8 +67,9 @@ const filetypes: FileTypes = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function getFileType(name: string): string {
|
export function getFileType(name: string): string {
|
||||||
const ext = name.split('.').pop()?.toLowerCase()
|
const dotIndex = name.lastIndexOf('.')
|
||||||
if (!ext || ext.length === name.length) return 'unknown'
|
if (dotIndex === -1 || dotIndex === name.length - 1) return 'unknown'
|
||||||
|
const ext = name.slice(dotIndex + 1).toLowerCase()
|
||||||
return Object.keys(filetypes).find(type => filetypes[type].includes(ext)) || 'unknown'
|
return Object.keys(filetypes).find(type => filetypes[type].includes(ext)) || 'unknown'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,10 +13,6 @@
|
|||||||
:path="props.path"
|
:path="props.path"
|
||||||
:documents="documents"
|
:documents="documents"
|
||||||
/>
|
/>
|
||||||
<div v-if="!store.prefs.gallery && documents.some(doc => doc.previewable)" class="suggest-gallery">
|
|
||||||
<SvgButton name="eye" taborder=0 @click="() => { store.prefs.gallery = true }"></SvgButton>
|
|
||||||
Gallery View
|
|
||||||
</div>
|
|
||||||
<EmptyFolder :documents=documents :path=props.path />
|
<EmptyFolder :documents=documents :path=props.path />
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -93,15 +89,4 @@ watch(documents, (docs) => {
|
|||||||
text-shadow: 0 0 .3rem #000, 0 0 2rem #0008;
|
text-shadow: 0 0 .3rem #000, 0 0 2rem #0008;
|
||||||
color: var(--accent-color);
|
color: var(--accent-color);
|
||||||
}
|
}
|
||||||
.suggest-gallery p {
|
|
||||||
font-size: 2rem;
|
|
||||||
color: var(--accent-color);
|
|
||||||
}
|
|
||||||
.suggest-gallery {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user