bookmarks/src/components/BookmarksList.vue

178 lines
4.2 KiB
Vue
Raw Normal View History

2019-07-26 18:16:37 +00:00
<template>
<div
:class="{
bookmarkslist: true,
'bookmarkslist--gridview': viewMode === 'grid'
2020-07-17 09:23:19 +00:00
}"
@scroll="onScroll">
<CreateBookmark v-if="newBookmark" />
<CreateFolder v-if="newFolder" />
<template v-if="$route.name === routes.FOLDER || $route.name === routes.HOME">
2020-07-23 13:12:45 +00:00
<!-- FOLDER VIEW WITH CUSTOM SORTING -->
2020-07-28 08:53:23 +00:00
<template v-if="sortOrder === 'index'">
2020-07-23 13:12:45 +00:00
<template v-for="item in children">
<Folder
v-if="item.type === 'folder' && getFolder(item.id)"
2020-07-23 13:12:45 +00:00
:key="item.type + item.id"
2020-07-28 08:53:23 +00:00
:folder="getFolder(item.id)" />
2020-07-23 13:12:45 +00:00
<Bookmark
2020-07-28 08:53:23 +00:00
v-if="item.type === 'bookmark' && getBookmark(item.id)"
2020-07-23 13:12:45 +00:00
:key="item.type + item.id"
2020-07-28 08:53:23 +00:00
:bookmark="getBookmark(item.id)" />
2020-07-23 13:12:45 +00:00
</template>
</template>
<!-- FOLDER VIEW WITH NORMAL SORTING -->
<template v-else>
<Folder
v-for="folder in subFolders"
:key="'folder' + folder.id"
:folder="folder" />
<template v-if="bookmarks.length">
<Bookmark
v-for="bookmark in bookmarks"
:key="'bookmark' + bookmark.id"
:bookmark="bookmark" />
</template>
</template>
</template>
2020-07-23 13:12:45 +00:00
<!-- NON-FOLDER VIEW -->
<template v-else-if="bookmarks.length">
<Bookmark
v-for="bookmark in bookmarks"
2020-07-23 13:12:45 +00:00
:key="'bookmark' + bookmark.id"
:bookmark="bookmark" />
</template>
<div
2020-07-30 15:56:02 +00:00
v-else-if="!loading && !bookmarks.length && !subFolders.length"
class="bookmarkslist__empty">
<h2>{{ t('bookmarks', 'No bookmarks here') }}</h2>
<p>{{ t('bookmarks', 'Try changing your query or add some using the button on the left.') }}</p>
</div>
<div v-if="loading" class="bookmarkslist__loading">
2019-10-05 21:24:54 +00:00
<figure class="icon-loading" />
</div>
</div>
2019-07-26 18:16:37 +00:00
</template>
<script>
2020-03-31 16:47:50 +00:00
import Bookmark from './Bookmark'
import Folder from './Folder'
import CreateBookmark from './CreateBookmark'
import CreateFolder from './CreateFolder'
import { actions } from '../store'
2019-07-26 18:16:37 +00:00
2020-03-31 16:47:50 +00:00
export default {
2019-08-13 19:35:32 +00:00
name: 'BookmarksList',
2019-07-26 18:16:37 +00:00
components: {
2019-08-26 12:57:02 +00:00
Bookmark,
Folder,
2019-08-15 13:38:39 +00:00
CreateBookmark,
CreateFolder,
2019-07-26 18:16:37 +00:00
},
props: {
bookmarks: {
type: Array,
required: true,
2019-08-04 21:49:07 +00:00
},
2019-08-13 19:35:32 +00:00
loading: {
2019-08-04 21:49:07 +00:00
type: Boolean,
required: true,
},
2019-08-13 19:35:32 +00:00
},
computed: {
2020-07-23 13:12:45 +00:00
children() {
if (this.$route.name !== this.routes.HOME && this.$route.name !== this.routes.FOLDER) {
return []
}
const folderId = this.$route.params.folder || '-1'
if (!folderId) return []
return this.$store.getters.getFolderChildren(folderId)
},
subFolders() {
if (this.$route.name !== this.routes.HOME && this.$route.name !== this.routes.FOLDER) {
return []
2019-08-20 14:19:21 +00:00
}
const folderId = this.$route.params.folder || '-1'
if (!folderId) return []
const folder = this.$store.getters.getFolder(folderId)[0]
2020-07-23 13:12:45 +00:00
this.$store.dispatch(actions.LOAD_SHARES_OF_FOLDER, folderId)
return folder.children
2019-08-04 21:49:07 +00:00
},
2019-08-13 19:35:32 +00:00
newBookmark() {
return this.$store.state.displayNewBookmark
2019-08-04 21:49:07 +00:00
},
2019-08-15 13:38:39 +00:00
newFolder() {
return this.$store.state.displayNewFolder
2019-08-24 17:10:20 +00:00
},
viewMode() {
return this.$store.state.viewMode
},
2020-07-28 08:53:23 +00:00
sortOrder() {
return this.$store.state.settings.sorting
},
},
2020-07-17 09:23:19 +00:00
methods: {
onScroll() {
if (
this.$el.scrollHeight
< this.$el.scrollTop + this.$el.clientHeight + 500
) {
this.$store.dispatch(actions.FETCH_PAGE)
}
},
2020-07-28 08:53:23 +00:00
getFolder(id) {
return this.$store.getters.getFolder(id)[0]
},
getBookmark(id) {
return this.$store.getters.getBookmark(id)
},
2020-07-17 09:23:19 +00:00
},
}
2019-07-26 18:16:37 +00:00
</script>
2019-08-04 21:49:07 +00:00
<style>
.bookmarkslist {
/* 50px header; 50px breadcrumbs */
height: calc(100vh - 50px - 50px);
overflow-y: scroll;
position: relative;
}
2019-08-26 12:57:02 +00:00
.bookmarkslist
> *:first-child:not(.bookmarkslist__loading):not(.bookmarkslist__empty) {
2019-08-04 21:49:07 +00:00
border-top: 1px solid var(--color-border);
}
2019-08-26 22:41:52 +00:00
2019-08-26 12:57:02 +00:00
.bookmarkslist__loading,
.bookmarkslist__empty {
2019-08-04 21:49:07 +00:00
width: 200px;
margin: 200px auto;
}
2019-08-26 22:41:52 +00:00
2019-08-26 12:57:02 +00:00
.bookmarkslist__loading {
2019-08-04 21:49:07 +00:00
text-align: center;
}
2019-08-24 17:10:20 +00:00
2019-08-26 12:57:02 +00:00
.bookmarkslist--gridview {
2019-08-24 17:10:20 +00:00
display: flex;
flex-flow: wrap;
2020-07-28 08:53:23 +00:00
align-content: start;
gap: 10px;
padding: 0 10px;
2019-08-24 17:10:20 +00:00
}
2019-08-26 22:41:52 +00:00
2019-08-26 18:07:25 +00:00
.folder--gridview,
.bookmark--gridview,
2019-08-26 12:57:02 +00:00
.bookmarkslist--gridview > .create-folder,
.bookmarkslist--gridview > .create-bookmark {
2019-09-14 14:36:27 +00:00
min-width: 200px;
2019-08-25 15:10:06 +00:00
max-width: 300px;
2019-08-24 17:10:20 +00:00
flex: 1;
height: 200px;
align-items: flex-end;
background: var(--color-main-background);
2019-08-24 17:10:20 +00:00
border: 1px solid var(--color-border);
box-shadow: #efefef7d 0px 0 13px 0px inset;
2019-08-26 18:07:25 +00:00
border-radius: var(--border-radius);
2019-08-24 17:10:20 +00:00
}
2019-08-04 21:49:07 +00:00
</style>