| 
									
										
										
										
											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)" /> | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  | </ModalDialog> | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  |   import ModalDialog from './ModalDialog.html' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   import { store } from '../../../_store/store' | 
					
						
							|  |  |  |   import { POST_PRIVACY_OPTIONS } from '../../../_static/statuses' | 
					
						
							|  |  |  |   import { setPostPrivacy } from '../../../_actions/postPrivacy' | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |   import GenericDialogList from './GenericDialogList.html' | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |   import { show } from '../helpers/showDialog' | 
					
						
							|  |  |  |   import { close } from '../helpers/closeDialog' | 
					
						
							|  |  |  |   import { oncreate } from '../helpers/onCreateDialog' | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export default { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |     oncreate, | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  |     components: { | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |       ModalDialog, | 
					
						
							|  |  |  |       GenericDialogList | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     store: () => store, | 
					
						
							|  |  |  |     data: () => ({ | 
					
						
							|  |  |  |       postPrivacyOptions: POST_PRIVACY_OPTIONS | 
					
						
							|  |  |  |     }), | 
					
						
							|  |  |  |     methods: { | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |       show, | 
					
						
							|  |  |  |       close, | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |       onClick(item) { | 
					
						
							|  |  |  |         setPostPrivacy(this.get('realm'), item.key) | 
					
						
							| 
									
										
										
										
											2018-04-08 16:56:20 -07:00
										 |  |  |         this.close() | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     computed: { | 
					
						
							| 
									
										
										
										
											2018-03-03 14:15:50 -08:00
										 |  |  |       composeData: ($currentComposeData, realm) => $currentComposeData[realm] || {}, | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  |       postPrivacy: (postPrivacyKey) => { | 
					
						
							|  |  |  |         return POST_PRIVACY_OPTIONS.find(_ => _.key === postPrivacyKey) | 
					
						
							|  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2018-03-03 14:15:50 -08:00
										 |  |  |       postPrivacyKey: (composeData, $currentVerifyCredentials) => { | 
					
						
							|  |  |  |         return composeData.postPrivacy || $currentVerifyCredentials.source.privacy | 
					
						
							| 
									
										
										
										
											2018-03-11 19:40:32 -07:00
										 |  |  |       }, | 
					
						
							|  |  |  |       items: (postPrivacy, postPrivacyOptions) => { | 
					
						
							|  |  |  |         return postPrivacyOptions.map(option => ({ | 
					
						
							|  |  |  |           key: option.key, | 
					
						
							|  |  |  |           label: option.label, | 
					
						
							|  |  |  |           icon: option.icon, | 
					
						
							|  |  |  |           selected: postPrivacy.key === option.key | 
					
						
							|  |  |  |         })) | 
					
						
							| 
									
										
										
										
											2018-03-03 13:23:26 -08:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </script> |