Refactor settings/email to use Composition API (#8576)
* refactor(client): refactor settings/email to use Composition API * fix(client): switch to non-null assertion for settings values
This commit is contained in:
		
							parent
							
								
									247a9deb02
								
							
						
					
					
						commit
						7a51f0ac94
					
				|  | @ -39,8 +39,8 @@ | |||
| </div> | ||||
| </template> | ||||
| 
 | ||||
| <script lang="ts"> | ||||
| import { defineComponent, onMounted, ref, watch } from 'vue'; | ||||
| <script lang="ts" setup> | ||||
| import { defineExpose, onMounted, ref, watch } from 'vue'; | ||||
| import FormSection from '@/components/form/section.vue'; | ||||
| import FormInput from '@/components/form/input.vue'; | ||||
| import FormSwitch from '@/components/form/switch.vue'; | ||||
|  | @ -49,79 +49,62 @@ import * as symbols from '@/symbols'; | |||
| import { $i } from '@/account'; | ||||
| import { i18n } from '@/i18n'; | ||||
| 
 | ||||
| export default defineComponent({ | ||||
| 	components: { | ||||
| 		FormSection, | ||||
| 		FormSwitch, | ||||
| 		FormInput, | ||||
| 	}, | ||||
| const emailAddress = ref($i!.email); | ||||
| 
 | ||||
| 	emits: ['info'], | ||||
| const onChangeReceiveAnnouncementEmail = (v) => { | ||||
| 	os.api('i/update', { | ||||
| 		receiveAnnouncementEmail: v | ||||
| 	}); | ||||
| }; | ||||
| 
 | ||||
| 	setup(props, context) { | ||||
| 		const emailAddress = ref($i.email); | ||||
| 
 | ||||
| 		const INFO = { | ||||
| 			title: i18n.ts.email, | ||||
| 			icon: 'fas fa-envelope', | ||||
| 			bg: 'var(--bg)', | ||||
| 		}; | ||||
| 
 | ||||
| 		const onChangeReceiveAnnouncementEmail = (v) => { | ||||
| 			os.api('i/update', { | ||||
| 				receiveAnnouncementEmail: v | ||||
| 			}); | ||||
| 		}; | ||||
| 
 | ||||
| 		const saveEmailAddress = () => { | ||||
| 			os.inputText({ | ||||
| 				title: i18n.ts.password, | ||||
| 				type: 'password' | ||||
| 			}).then(({ canceled, result: password }) => { | ||||
| 				if (canceled) return; | ||||
| 				os.apiWithDialog('i/update-email', { | ||||
| 					password: password, | ||||
| 					email: emailAddress.value, | ||||
| 				}); | ||||
| 			}); | ||||
| 		}; | ||||
| 
 | ||||
| 		const emailNotification_mention = ref($i.emailNotificationTypes.includes('mention')); | ||||
| 		const emailNotification_reply = ref($i.emailNotificationTypes.includes('reply')); | ||||
| 		const emailNotification_quote = ref($i.emailNotificationTypes.includes('quote')); | ||||
| 		const emailNotification_follow = ref($i.emailNotificationTypes.includes('follow')); | ||||
| 		const emailNotification_receiveFollowRequest = ref($i.emailNotificationTypes.includes('receiveFollowRequest')); | ||||
| 		const emailNotification_groupInvited = ref($i.emailNotificationTypes.includes('groupInvited')); | ||||
| 
 | ||||
| 		const saveNotificationSettings = () => { | ||||
| 			os.api('i/update', { | ||||
| 				emailNotificationTypes: [ | ||||
| 					...[emailNotification_mention.value ? 'mention' : null], | ||||
| 					...[emailNotification_reply.value ? 'reply' : null], | ||||
| 					...[emailNotification_quote.value ? 'quote' : null], | ||||
| 					...[emailNotification_follow.value ? 'follow' : null], | ||||
| 					...[emailNotification_receiveFollowRequest.value ? 'receiveFollowRequest' : null], | ||||
| 					...[emailNotification_groupInvited.value ? 'groupInvited' : null], | ||||
| 				].filter(x => x != null) | ||||
| 			}); | ||||
| 		}; | ||||
| 
 | ||||
| 		watch([emailNotification_mention, emailNotification_reply, emailNotification_quote, emailNotification_follow, emailNotification_receiveFollowRequest, emailNotification_groupInvited], () => { | ||||
| 			saveNotificationSettings(); | ||||
| const saveEmailAddress = () => { | ||||
| 	os.inputText({ | ||||
| 		title: i18n.ts.password, | ||||
| 		type: 'password' | ||||
| 	}).then(({ canceled, result: password }) => { | ||||
| 		if (canceled) return; | ||||
| 		os.apiWithDialog('i/update-email', { | ||||
| 			password: password, | ||||
| 			email: emailAddress.value, | ||||
| 		}); | ||||
| 	}); | ||||
| }; | ||||
| 
 | ||||
| 		onMounted(() => { | ||||
| 			watch(emailAddress, () => { | ||||
| 				saveEmailAddress(); | ||||
| 			}); | ||||
| 		}); | ||||
| const emailNotification_mention = ref($i!.emailNotificationTypes.includes('mention')); | ||||
| const emailNotification_reply = ref($i!.emailNotificationTypes.includes('reply')); | ||||
| const emailNotification_quote = ref($i!.emailNotificationTypes.includes('quote')); | ||||
| const emailNotification_follow = ref($i!.emailNotificationTypes.includes('follow')); | ||||
| const emailNotification_receiveFollowRequest = ref($i!.emailNotificationTypes.includes('receiveFollowRequest')); | ||||
| const emailNotification_groupInvited = ref($i!.emailNotificationTypes.includes('groupInvited')); | ||||
| 
 | ||||
| 		return { | ||||
| 			[symbols.PAGE_INFO]: INFO, | ||||
| 			emailAddress, | ||||
| 			onChangeReceiveAnnouncementEmail, | ||||
| 			emailNotification_mention, emailNotification_reply, emailNotification_quote, emailNotification_follow, emailNotification_receiveFollowRequest, emailNotification_groupInvited, | ||||
| 		}; | ||||
| 	}, | ||||
| const saveNotificationSettings = () => { | ||||
| 	os.api('i/update', { | ||||
| 		emailNotificationTypes: [ | ||||
| 			...[emailNotification_mention.value ? 'mention' : null], | ||||
| 			...[emailNotification_reply.value ? 'reply' : null], | ||||
| 			...[emailNotification_quote.value ? 'quote' : null], | ||||
| 			...[emailNotification_follow.value ? 'follow' : null], | ||||
| 			...[emailNotification_receiveFollowRequest.value ? 'receiveFollowRequest' : null], | ||||
| 			...[emailNotification_groupInvited.value ? 'groupInvited' : null], | ||||
| 		].filter(x => x != null) | ||||
| 	}); | ||||
| }; | ||||
| 
 | ||||
| watch([emailNotification_mention, emailNotification_reply, emailNotification_quote, emailNotification_follow, emailNotification_receiveFollowRequest, emailNotification_groupInvited], () => { | ||||
| 	saveNotificationSettings(); | ||||
| }); | ||||
| 
 | ||||
| onMounted(() => { | ||||
| 	watch(emailAddress, () => { | ||||
| 		saveEmailAddress(); | ||||
| 	}); | ||||
| }); | ||||
| 
 | ||||
| defineExpose({ | ||||
| 	[symbols.PAGE_INFO]: { | ||||
| 		title: i18n.ts.email, | ||||
| 		icon: 'fas fa-envelope', | ||||
| 		bg: 'var(--bg)', | ||||
| 	} | ||||
| }); | ||||
| </script> | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue