| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  | <ModalDialog | 
					
						
							| 
									
										
										
										
											2018-05-01 17:05:36 -07:00
										 |  |  |   {id} | 
					
						
							|  |  |  |   {label} | 
					
						
							|  |  |  |   {title} | 
					
						
							| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  |   background="var(--main-bg)" | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2018-08-17 22:26:08 -07:00
										 |  |  |   <GenericDialogList selectable={false} {items} on:click="onClick(event)"/> | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  | </ModalDialog> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import ModalDialog from './ModalDialog.html' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  | import { store } from '../../../_store/store' | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  | import GenericDialogList from './GenericDialogList.html' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  | import { setAccountFollowed } from '../../../_actions/follow' | 
					
						
							|  |  |  | import { doDeleteStatus } from '../../../_actions/delete' | 
					
						
							|  |  |  | import { show } from '../helpers/showDialog' | 
					
						
							|  |  |  | import { close } from '../helpers/closeDialog' | 
					
						
							|  |  |  | import { oncreate } from '../helpers/onCreateDialog' | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  | import { setAccountBlocked } from '../../../_actions/block' | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  | import { setAccountMuted } from '../../../_actions/mute' | 
					
						
							| 
									
										
										
										
											2018-04-29 12:28:44 -07:00
										 |  |  | import { setStatusPinnedOrUnpinned } from '../../../_actions/pin' | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  | import { importShowCopyDialog } from '../asyncDialogs' | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  | import { setConversationMuted } from '../../../_actions/muteConversation' | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   oncreate, | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |   computed: { | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |     relationship: ({$currentAccountRelationship}) => $currentAccountRelationship, | 
					
						
							|  |  |  |     account: ({$currentAccountProfile}) => $currentAccountProfile, | 
					
						
							|  |  |  |     verifyCredentials: ({$currentVerifyCredentials}) => $currentVerifyCredentials, | 
					
						
							|  |  |  |     statusId: ({status}) => status.id, | 
					
						
							|  |  |  |     pinned: ({status}) => status.pinned, | 
					
						
							|  |  |  |     // | 
					
						
							|  |  |  |     // begin copypasta (StatusOptionsDialog.html / AccountProfileOptionsDialog.html) | 
					
						
							|  |  |  |     // | 
					
						
							|  |  |  |     verifyCredentialsId: ({verifyCredentials}) => verifyCredentials.id, | 
					
						
							|  |  |  |     following: ({relationship}) => relationship && relationship.following, | 
					
						
							|  |  |  |     followRequested: ({relationship}) => relationship && relationship.requested, | 
					
						
							|  |  |  |     accountId: ({account}) => account && account.id, | 
					
						
							|  |  |  |     acct: ({account}) => account.acct, | 
					
						
							|  |  |  |     muting: ({relationship}) => relationship.muting, | 
					
						
							|  |  |  |     blocking: ({relationship}) => relationship.blocking, | 
					
						
							|  |  |  |     followLabel: ({following, followRequested, account, acct}) => { | 
					
						
							| 
									
										
										
										
											2018-04-05 07:44:10 -07:00
										 |  |  |       if (typeof following === 'undefined' || !account) { | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |         return '' | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-03-14 22:14:06 -07:00
										 |  |  |       return (following || followRequested) | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |         ? `Unfollow @${acct}` | 
					
						
							|  |  |  |         : `Follow @${acct}` | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |     followIcon: ({following, followRequested}) => ( | 
					
						
							|  |  |  |       following ? '#fa-user-times' : followRequested ? '#fa-hourglass' : '#fa-user-plus' | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     blockLabel: ({blocking, acct}) => ( | 
					
						
							|  |  |  |       blocking ? `Unblock @${acct}` : `Block @${acct}` | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     blockIcon: ({blocking}) => blocking ? '#fa-unlock' : '#fa-ban', | 
					
						
							|  |  |  |     muteLabel: ({muting, acct}) => ( | 
					
						
							|  |  |  |       muting ? `Unmute @${acct}` : `Mute @${acct}` | 
					
						
							|  |  |  |     ), | 
					
						
							|  |  |  |     muteIcon: ({muting}) => muting ? '#fa-volume-up' : '#fa-volume-off', | 
					
						
							|  |  |  |     isUser: ({accountId, verifyCredentialsId}) => accountId === verifyCredentialsId, | 
					
						
							|  |  |  |     // | 
					
						
							|  |  |  |     // end copypasta (StatusOptionsDialog.html / AccountProfileOptionsDialog.html) | 
					
						
							|  |  |  |     // | 
					
						
							|  |  |  |     pinLabel: ({pinned, isUser}) => isUser ? (pinned ? 'Unpin from profile' : 'Pin to profile') : '', | 
					
						
							| 
									
										
										
										
											2018-05-12 15:45:50 -07:00
										 |  |  |     visibility: ({status}) => status.visibility, | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  |     mentions: ({status}) => status.mentions || [], | 
					
						
							|  |  |  |     mentionsUser: ({mentions, verifyCredentialsId}) => !!mentions.find(_ => _.id === verifyCredentialsId), | 
					
						
							|  |  |  |     mutingConversation: ({status}) => !!status.muted, | 
					
						
							|  |  |  |     muteConversationLabel: ({mutingConversation}) => mutingConversation ? `Unmute conversation` : `Mute conversation`, | 
					
						
							|  |  |  |     muteConversationIcon: ({mutingConversation}) => mutingConversation ? '#fa-volume-up' : '#fa-volume-off', | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |     items: ({ | 
					
						
							|  |  |  |       blockLabel, blocking, blockIcon, muteLabel, muteIcon, followLabel, followIcon, | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  |       following, followRequested, pinLabel, isUser, visibility, mentionsUser, mutingConversation, | 
					
						
							|  |  |  |       muteConversationLabel, muteConversationIcon | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |     }) => ([ | 
					
						
							|  |  |  |       isUser && { | 
					
						
							|  |  |  |         key: 'delete', | 
					
						
							|  |  |  |         label: 'Delete', | 
					
						
							|  |  |  |         icon: '#fa-trash' | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-05-12 15:45:50 -07:00
										 |  |  |       visibility !== 'private' && visibility !== 'direct' && isUser && { | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |         key: 'pin', | 
					
						
							|  |  |  |         label: pinLabel, | 
					
						
							|  |  |  |         icon: '#fa-thumb-tack' | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       !isUser && !blocking && { | 
					
						
							|  |  |  |         key: 'follow', | 
					
						
							|  |  |  |         label: followLabel, | 
					
						
							|  |  |  |         icon: followIcon | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       !isUser && { | 
					
						
							|  |  |  |         key: 'block', | 
					
						
							|  |  |  |         label: blockLabel, | 
					
						
							|  |  |  |         icon: blockIcon | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       !isUser && !blocking && { | 
					
						
							|  |  |  |         key: 'mute', | 
					
						
							|  |  |  |         label: muteLabel, | 
					
						
							|  |  |  |         icon: muteIcon | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  |       (isUser || mentionsUser) && { | 
					
						
							|  |  |  |         key: 'muteConversation', | 
					
						
							|  |  |  |         label: muteConversationLabel, | 
					
						
							|  |  |  |         icon: muteConversationIcon | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |       { | 
					
						
							|  |  |  |         key: 'copy', | 
					
						
							|  |  |  |         label: 'Copy link to toot', | 
					
						
							| 
									
										
										
										
											2018-05-26 17:23:27 -07:00
										 |  |  |         icon: '#fa-link' | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |       } | 
					
						
							|  |  |  |     ].filter(Boolean)) | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |   }, | 
					
						
							|  |  |  |   components: { | 
					
						
							|  |  |  |     ModalDialog, | 
					
						
							|  |  |  |     GenericDialogList | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   store: () => store, | 
					
						
							|  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |     show, | 
					
						
							|  |  |  |     close, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     onClick (item) { | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |       switch (item.key) { | 
					
						
							|  |  |  |         case 'delete': | 
					
						
							|  |  |  |           return this.onDeleteClicked() | 
					
						
							| 
									
										
										
										
											2018-04-29 12:28:44 -07:00
										 |  |  |         case 'pin': | 
					
						
							|  |  |  |           return this.onPinClicked() | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |         case 'follow': | 
					
						
							|  |  |  |           return this.onFollowClicked() | 
					
						
							|  |  |  |         case 'block': | 
					
						
							|  |  |  |           return this.onBlockClicked() | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |         case 'mute': | 
					
						
							|  |  |  |           return this.onMuteClicked() | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |         case 'copy': | 
					
						
							|  |  |  |           return this.onCopyClicked() | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  |         case 'muteConversation': | 
					
						
							|  |  |  |           return this.onMuteConversationClicked() | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     async onDeleteClicked () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { statusId } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |       this.close() | 
					
						
							|  |  |  |       await doDeleteStatus(statusId) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-29 12:28:44 -07:00
										 |  |  |     async onPinClicked () { | 
					
						
							|  |  |  |       let { statusId, pinned } = this.get() | 
					
						
							|  |  |  |       this.close() | 
					
						
							|  |  |  |       await setStatusPinnedOrUnpinned(statusId, !pinned, true) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     async onFollowClicked () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { accountId, following } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |       this.close() | 
					
						
							|  |  |  |       await setAccountFollowed(accountId, !following, true) | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     async onBlockClicked () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { accountId, blocking } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |       this.close() | 
					
						
							|  |  |  |       await setAccountBlocked(accountId, !blocking, true) | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |     async onMuteClicked () { | 
					
						
							| 
									
										
										
										
											2018-04-19 09:37:05 -07:00
										 |  |  |       let { accountId, muting } = this.get() | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |       this.close() | 
					
						
							|  |  |  |       await setAccountMuted(accountId, !muting, true) | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |     async onCopyClicked () { | 
					
						
							|  |  |  |       let { status } = this.get() | 
					
						
							|  |  |  |       let { url } = status | 
					
						
							|  |  |  |       let showCopyDialog = await importShowCopyDialog() | 
					
						
							| 
									
										
										
										
											2018-05-13 11:13:35 -07:00
										 |  |  |       this.close() | 
					
						
							| 
									
										
										
										
											2018-05-12 15:00:11 -07:00
										 |  |  |       showCopyDialog(url) | 
					
						
							| 
									
										
										
										
											2018-05-12 22:49:01 -07:00
										 |  |  |     }, | 
					
						
							|  |  |  |     async onMuteConversationClicked () { | 
					
						
							|  |  |  |       let { statusId, mutingConversation } = this.get() | 
					
						
							|  |  |  |       this.close() | 
					
						
							|  |  |  |       await setConversationMuted(statusId, !mutingConversation, true) | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> |