#436: add dismiss button, disable is_seen part

This commit is contained in:
dave 2019-03-13 14:08:03 -04:00
parent cd9a7dd488
commit 2f7d890ad2
5 changed files with 68 additions and 62 deletions

View File

@ -1,7 +1,12 @@
<template> <template>
<div class="notification-item"> <status
<button @click.prevent="dismiss" class="btn-dismiss">{{$t("notifications.dismiss")}}</button> v-if="notification.type === 'mention'"
<status v-if="notification.type === 'mention'" :compact="true" :statusoid="notification.status"></status> :compact="true"
:statusoid="notification.status"
isNotification="true"
@dismissNotification="dismiss"
>
</status>
<div class="non-mention" :class="[userClass, { highlighted: userStyle }]" :style="[ userStyle ]"v-else> <div class="non-mention" :class="[userClass, { highlighted: userStyle }]" :style="[ userStyle ]"v-else>
<a class='avatar-container' :href="notification.action.user.statusnet_profile_url" @click.stop.prevent.capture="toggleUserExpanded"> <a class='avatar-container' :href="notification.action.user.statusnet_profile_url" @click.stop.prevent.capture="toggleUserExpanded">
<UserAvatar :compact="true" :betterShadow="betterShadow" :src="notification.action.user.profile_image_url_original"/> <UserAvatar :compact="true" :betterShadow="betterShadow" :src="notification.action.user.profile_image_url_original"/>
@ -30,6 +35,9 @@
<timeago :since="notification.action.created_at" :auto-update="240"></timeago> <timeago :since="notification.action.created_at" :auto-update="240"></timeago>
</router-link> </router-link>
</div> </div>
<span class="button-icon" @click.prevent="dismiss">
<i class="button-icon icon-cancel delete-status"></i>
</span>
</span> </span>
<div class="follow-text" v-if="notification.type === 'follow'"> <div class="follow-text" v-if="notification.type === 'follow'">
<router-link :to="userProfileLink(notification.action.user)"> <router-link :to="userProfileLink(notification.action.user)">
@ -41,17 +49,6 @@
</template> </template>
</div> </div>
</div> </div>
</div>
</template> </template>
<script src="./notification.js"></script> <script src="./notification.js"></script>
<style lang="scss">
@import '../../_variables.scss';
.notification-item {
display: flex;
flex: 1;
flex-direction: column;
}
</style>

View File

@ -25,7 +25,8 @@ const Status = {
'replies', 'replies',
'isPreview', 'isPreview',
'noHeading', 'noHeading',
'inlineExpanded' 'inlineExpanded',
'isNotification'
], ],
data () { data () {
return { return {
@ -365,6 +366,9 @@ const Status = {
setMedia () { setMedia () {
const attachments = this.attachmentSize === 'hide' ? this.status.attachments : this.galleryAttachments const attachments = this.attachmentSize === 'hide' ? this.status.attachments : this.galleryAttachments
return () => this.$store.dispatch('setMedia', attachments) return () => this.$store.dispatch('setMedia', attachments)
},
dismissNotification () {
this.$emit('dismissNotification')
} }
}, },
watch: { watch: {

View File

@ -52,6 +52,9 @@
<a :href="status.external_url" target="_blank" v-if="!status.is_local && !isPreview" class="source_url" title="Source"> <a :href="status.external_url" target="_blank" v-if="!status.is_local && !isPreview" class="source_url" title="Source">
<i class="button-icon icon-link-ext-alt"></i> <i class="button-icon icon-link-ext-alt"></i>
</a> </a>
<span class="button-icon" v-if="isNotification" @click.prevent="dismissNotification">
<i class="button-icon icon-cancel delete-status"></i>
</span>
<template v-if="expandable && !isPreview"> <template v-if="expandable && !isPreview">
<a href="#" @click.prevent="toggleExpanded" title="Expand"> <a href="#" @click.prevent="toggleExpanded" title="Expand">
<i class="button-icon icon-plus-squared"></i> <i class="button-icon icon-plus-squared"></i>

View File

@ -65,8 +65,7 @@ export const parseUser = (data) => {
output.muted = pleroma.muted output.muted = pleroma.muted
} }
// Missing, trying to recover // TODO: handle is_local
output.is_local = !output.screen_name.includes('@')
} else { } else {
output.screen_name = data.screen_name output.screen_name = data.screen_name
@ -179,8 +178,7 @@ export const parseStatus = (data) => {
output.summary_html = data.spoiler_text output.summary_html = data.spoiler_text
output.external_url = data.url output.external_url = data.url
// FIXME missing!! // TODO: handle is_local
output.is_local = false
} else { } else {
output.favorited = data.favorited output.favorited = data.favorited
output.fave_num = data.fave_num output.fave_num = data.fave_num

View File

@ -16,17 +16,21 @@ const fetchAndUpdate = ({store, credentials, older = false}) => {
args['until'] = timelineData.minId args['until'] = timelineData.minId
} }
} else { } else {
// load unread notifications repeadedly to provide consistency between browser tabs if (timelineData.maxId !== Number.POSITIVE_INFINITY) {
const notifications = timelineData.data
const unread = notifications.filter(n => !n.seen).map(n => n.id)
if (!unread.length) {
args['since'] = timelineData.maxId args['since'] = timelineData.maxId
} else {
args['since'] = Math.min(...unread) - 1
if (timelineData.maxId !== Math.max(...unread)) {
args['until'] = Math.max(...unread, args['since'] + 20)
}
} }
// # disabled until is_seen is impelented on the BE
// load unread notifications repeadedly to provide consistency between browser tabs
// const notifications = timelineData.data
// const unread = notifications.filter(n => !n.seen).map(n => n.id)
// if (!unread.length) {
// args['since'] = timelineData.maxId
// } else {
// args['since'] = Math.min(...unread) - 1
// if (timelineData.maxId !== Math.max(...unread)) {
// args['until'] = Math.max(...unread, args['since'] + 20)
// }
// }
} }
args['timeline'] = 'notifications' args['timeline'] = 'notifications'