Update CollectionComponent

This commit is contained in:
Daniel Supernault 2019-11-10 18:19:00 -07:00
parent 16631d3599
commit 420131a1ad
No known key found for this signature in database
GPG key ID: 0DEF1C662C9033F7

View file

@ -15,7 +15,14 @@
</p> </p>
<p v-if="owner == true" class="pt-3 text-center"> <p v-if="owner == true" class="pt-3 text-center">
<span> <span>
<button class="btn btn-outline-light btn-sm" @click.prevent="addToCollection">Add Photo</button> <button class="btn btn-outline-light btn-sm" @click.prevent="addToCollection">
<span v-if="loadingPostList == false">Add Photo</span>
<span v-else class="px-4">
<div class="spinner-border spinner-border-sm" role="status">
<span class="sr-only">Loading...</span>
</div>
</span>
</button>
&nbsp; &nbsp; &nbsp; &nbsp;
<button class="btn btn-outline-light btn-sm" @click.prevent="editCollection">Edit</button> <button class="btn btn-outline-light btn-sm" @click.prevent="editCollection">Edit</button>
&nbsp; &nbsp; &nbsp; &nbsp;
@ -62,7 +69,20 @@
<button type="button" class="btn btn-primary btn-sm py-1 font-weight-bold px-3 float-right" @click.prevent="updateCollection">Save</button> <button type="button" class="btn btn-primary btn-sm py-1 font-weight-bold px-3 float-right" @click.prevent="updateCollection">Save</button>
</form> </form>
</b-modal> </b-modal>
<b-modal ref="addPhotoModal" id="add-photo-modal" hide-footer centered title="Add Photo" body-class=""> <b-modal ref="addPhotoModal" id="add-photo-modal" hide-footer centered title="Add Photo" body-class="m-3">
<div class="form-group">
<label for="title" class="font-weight-bold text-muted">Add Recent Post</label>
<div class="row m-1" v-if="postsList.length > 0">
<div v-for="(p, index) in postsList" :key="'postList-'+index" class="col-4 p-1 cursor-pointer">
<div class="square">
<div class="square-content" v-bind:style="'background-image: url(' + p.media_attachments[0].url + ');'"></div>
</div>
</div>
<div class="col-12">
<hr>
</div>
</div>
</div>
<form> <form>
<div class="form-group"> <div class="form-group">
<label for="title" class="font-weight-bold text-muted">Add Post by URL</label> <label for="title" class="font-weight-bold text-muted">Add Post by URL</label>
@ -105,12 +125,15 @@ export default {
return { return {
loaded: false, loaded: false,
posts: [], posts: [],
ids: [],
currentUser: false, currentUser: false,
owner: false, owner: false,
title: this.collectionTitle, title: this.collectionTitle,
description: this.collectionDescription, description: this.collectionDescription,
visibility: this.collectionVisibility, visibility: this.collectionVisibility,
photoId: '' photoId: '',
postsList: [],
loadingPostList: false
} }
}, },
@ -135,6 +158,9 @@ export default {
axios.get('/api/local/collection/items/' + this.collectionId) axios.get('/api/local/collection/items/' + this.collectionId)
.then(res => { .then(res => {
this.posts = res.data; this.posts = res.data;
this.ids = this.posts.map(p => {
return p.id;
});
this.loaded = true; this.loaded = true;
}); });
}, },
@ -149,11 +175,34 @@ export default {
}, },
addToCollection() { addToCollection() {
let self = this;
this.loadingPostList = true;
if(this.postsList.length == 0) {
axios.get('/api/pixelfed/v1/accounts/'+this.profileId+'/statuses', {
params: {
min_id: 1,
limit: 13
}
})
.then(res => {
self.postsList = res.data.filter(l => {
return self.ids.indexOf(l.id) == -1;
}).splice(0,9);
self.loadingPostList = false;
self.$refs.addPhotoModal.show();
}).catch(err => {
self.loadingPostList = false;
swal('An Error Occured', 'We cannot process your request at this time, please try again later.', 'error');
})
} else {
this.$refs.addPhotoModal.show(); this.$refs.addPhotoModal.show();
this.loadingPostList = false;
}
}, },
pushId() { pushId() {
let max = 18; let max = 18;
let self = this;
if(this.posts.length >= max) { if(this.posts.length >= max) {
swal('Error', 'You can only add ' + max + ' posts per collection', 'error'); swal('Error', 'You can only add ' + max + ' posts per collection', 'error');
return; return;
@ -174,7 +223,7 @@ export default {
collection_id: this.collectionId, collection_id: this.collectionId,
post_id: split[5] post_id: split[5]
}).then(res => { }).then(res => {
location.reload(); self.ids.push(...split[5]);
}).catch(err => { }).catch(err => {
swal('Invalid URL', 'The post you entered was invalid', 'error'); swal('Invalid URL', 'The post you entered was invalid', 'error');
this.photoId = ''; this.photoId = '';