diff options
| author | Zephyrrus <[email protected]> | 2020-06-29 22:18:42 +0300 |
|---|---|---|
| committer | Zephyrrus <[email protected]> | 2020-06-29 22:18:42 +0300 |
| commit | 520062508ccad88d49229e603fc4d2c0c0a118d3 (patch) | |
| tree | 19b75c029c6e5e4ddc20e1f2fc96799d64e1705e /src/site/pages/dashboard | |
| parent | fix: heigh issues where the parent is smaller than the child (diff) | |
| download | host.fuwn.me-520062508ccad88d49229e603fc4d2c0c0a118d3.tar.xz host.fuwn.me-520062508ccad88d49229e603fc4d2c0c0a118d3.zip | |
feat: backend pagination
serverLoad++;
userRamUsage--;
Diffstat (limited to 'src/site/pages/dashboard')
| -rw-r--r-- | src/site/pages/dashboard/index.vue | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/src/site/pages/dashboard/index.vue b/src/site/pages/dashboard/index.vue index 8a4031b..64f8266 100644 --- a/src/site/pages/dashboard/index.vue +++ b/src/site/pages/dashboard/index.vue @@ -8,15 +8,16 @@ <div class="column"> <h2 class="subtitle">Your uploaded files</h2> <hr> + <!-- TODO: Add a list view so the user can see the files that don't have thumbnails, like text documents --> - <Grid v-if="files.length" - :files="paginatedFiles" + <Grid v-if="count" + :files="files" :enableSearch="false" class="grid" /> <b-pagination - v-if="files.length > perPage" - :total="files.length" + v-if="count > perPage" + :total="count" :per-page="perPage" :current.sync="current" class="pagination" @@ -46,25 +47,26 @@ export default { data() { return { files: [], + count: 0, current: 1, perPage: 20 }; }, - computed: { - paginatedFiles() { - return this.files.slice((this.current - 1) * this.perPage, this.current * this.perPage); - } - }, metaInfo() { return { title: 'Uploads' }; }, + watch: { + current: 'getFiles' + }, mounted() { this.getFiles(); }, methods: { async getFiles() { - const response = await this.$axios.$get(`files`); + // TODO: Cache a few pages once fetched + const response = await this.$axios.$get(`files`, { params: { page: this.current, limit: this.perPage }}); this.files = response.files; + this.count = response.count; } } }; |