| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  | <ModalDialog | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   :id | 
					
						
							| 
									
										
										
										
											2018-04-04 20:33:17 -07:00
										 |  |  |   :label | 
					
						
							|  |  |  |   :title | 
					
						
							|  |  |  |   background="var(--main-bg)" | 
					
						
							|  |  |  | > | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |   <GenericDialogList :items on:click="onClick(event)"/> | 
					
						
							|  |  |  | </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-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: { | 
					
						
							|  |  |  |     relationship: ($currentAccountRelationship) => $currentAccountRelationship, | 
					
						
							|  |  |  |     account: ($currentAccountProfile) => $currentAccountProfile, | 
					
						
							| 
									
										
										
										
											2018-03-14 08:36:12 -07:00
										 |  |  |     verifyCredentials: ($currentVerifyCredentials) => $currentVerifyCredentials, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     // begin account data copypasta | 
					
						
							| 
									
										
										
										
											2018-03-14 08:36:12 -07:00
										 |  |  |     verifyCredentialsId: (verifyCredentials) => verifyCredentials.id, | 
					
						
							| 
									
										
										
										
											2018-03-14 22:14:06 -07:00
										 |  |  |     following: (relationship) => relationship && relationship.following, | 
					
						
							|  |  |  |     followRequested: (relationship) => relationship && relationship.requested, | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |     accountId: (account) => account && account.id, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     acct: (account) => account.acct, | 
					
						
							|  |  |  |     muting: (relationship) => relationship.muting, | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |     blocking: (relationship) => relationship.blocking, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     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-04-14 22:18:48 -07:00
										 |  |  |     followIcon: (following, followRequested) => { | 
					
						
							|  |  |  |       return following ? '#fa-user-times' : followRequested ? '#fa-hourglass' : '#fa-user-plus' | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     blockLabel: (blocking, acct) => { | 
					
						
							|  |  |  |       return blocking ? `Unblock @${acct}` : `Block @${acct}` | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     blockIcon: (blocking) => blocking ? '#fa-unlock' : '#fa-ban', | 
					
						
							|  |  |  |     muteLabel: (muting, acct) => { | 
					
						
							|  |  |  |       return muting ? `Unmute @${acct}` : `Mute @${acct}` | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     muteIcon: (muting) => muting ? '#fa-volume-up' : '#fa-volume-off', | 
					
						
							|  |  |  |     // end account data copypasta | 
					
						
							|  |  |  |     items: (blockLabel, blocking, blockIcon, muteLabel, muteIcon, | 
					
						
							| 
									
										
										
										
											2018-04-19 21:38:01 -07:00
										 |  |  |       followLabel, followIcon, following, followRequested, | 
					
						
							|  |  |  |       accountId, verifyCredentialsId) => { | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |       let isUser = accountId === verifyCredentialsId | 
					
						
							|  |  |  |       return [ | 
					
						
							|  |  |  |         isUser && { | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |           key: 'delete', | 
					
						
							|  |  |  |           label: 'Delete', | 
					
						
							|  |  |  |           icon: '#fa-trash' | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |         !isUser && !blocking && { | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |           key: 'follow', | 
					
						
							|  |  |  |           label: followLabel, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |           icon: followIcon | 
					
						
							| 
									
										
										
										
											2018-03-14 08:36:12 -07:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |         !isUser && { | 
					
						
							| 
									
										
										
										
											2018-04-14 18:47:55 -07:00
										 |  |  |           key: 'block', | 
					
						
							|  |  |  |           label: blockLabel, | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |           icon: blockIcon | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         !isUser && !blocking && { | 
					
						
							|  |  |  |           key: 'mute', | 
					
						
							|  |  |  |           label: muteLabel, | 
					
						
							|  |  |  |           icon: muteIcon | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-14 08:36:12 -07:00
										 |  |  |       ].filter(Boolean) | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											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() | 
					
						
							|  |  |  |         case 'follow': | 
					
						
							|  |  |  |           return this.onFollowClicked() | 
					
						
							|  |  |  |         case 'block': | 
					
						
							|  |  |  |           return this.onBlockClicked() | 
					
						
							| 
									
										
										
										
											2018-04-14 22:18:48 -07:00
										 |  |  |         case 'mute': | 
					
						
							|  |  |  |           return this.onMuteClicked() | 
					
						
							| 
									
										
										
										
											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-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-03-11 19:40:32 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> |